- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 angular.js 中编写了一个指令,它基本上在屏幕上绘制方框来表示错误,每个错误都有一个弹出窗口,它是一个表格,每行包含一些信息列。为了简单起见,我在这里只保留了一个 href 。我的要求是,当我按下如下所示的抑制 href 时,应该调用相应的 javascipt 函数,但是在下面显示的代码中,函数 suppressKey 永远不会解析。有人能给我一些关于为什么会发生这种情况的指示吗?
指令
(function () {
var canvas;
var directive = function () {
return {
restrict: 'EA',
scope: {
componentId: '=',
componentName:'=',
siteName:'=',
popUpHtml:'=',
popupErrorDetails:'=',
onMouseEnter: '&',
onMouseLeave:'&'
},
templateUrl:'shared/directives/_square_draw.html',
link : function( scope, element ) {
var suppressKey = function() {
console.log( "Clicked on the suppress link" );
}
var generatePopupHtml = function( errors, exchangeName, onClickHandler ) {
var html_content = new Object();
html_content = '<h5 class="panel-danger">' + exchangeName + '</h5>';
html_content += '<table class="table table-bordered table-condensed table-hover" style="display=none">';
for (var index in errors) {
html_content += '<td><a href="#" onclick="suppressKey()">Suppress</a></td>';
html_content += '</tr>';
}
html_content += '</table>';
return html_content;
}
scope.$watch('[componentId,componentName,popupErrorDetails,siteName]',function(newValue) {
$('.myElement').smallipop();
var canvas = null;
var canvas = document.getElementById("canvas");
if( canvas === null ) {
canvas = document.getElementById( newValue[0] + newValue[3] );
}
canvas.id = newValue[0] + newValue[3];
canvas = document.getElementById(canvas.id);
var errors = newValue[2];
var innerHtml = generatePopupHtml( errors, newValue[1] );
canvas.innerHTML= '<div" id="' + canvas.id +'"><strong>' + newValue[1] + '</strong>' + '<span class="smallipop-hint">'+ innerHtml + '</span></div>';
}, true )
}
};
};
app.directive('squareDraw', directive);
}());
模板:
<div id="canvas" class="mdd-table-responsive table-bordered mdd-table-hover myElement" style="font-size: 10px;display:'none';background-color: #F3A793;min-height: 100%;min-width:95%;border:1px solid black;">
</div>
更新
嗨,我已经尝试了这里建议的内容,但无法获得结果,而使用范围和 $compile 很容易测试。我不确定帖子中建议的 jquery 更改,因此我再次发布我的代码以及我收到的错误。
var generatePopupHtml1 = function( errors, exchangeName ) {
var htmlContent = $('<div></div>');
htmlContent.append('<h5 class="panel-danger">' + exchangeName + '</h5>');
var table = $('<table class="table table-bordered table-condensed table-hover" style="display=none">');
for (var index in errors) {
table.append("<tr></tr>")
.append("<td></td>")
.append("<a href='#'>Suppress</a>")
.bind("click", function () {
console.log("bound event");
});
}
htmlContent.append(table);
return htmlContent;
}
修改 watch 功能
scope.$watch('[componentId,componentName,popupErrorDetails,siteName]',function(newValue) {
$('.myElement').smallipop();
var canvas = null;
var canvas = document.getElementById("canvas");
if( canvas === null ) {
canvas = document.getElementById( newValue[0] + newValue[3] );
}
canvas.id = newValue[0] + newValue[3];
canvas = document.getElementById(canvas.id);
var errors = newValue[2];
var tooltipSpan = $( '<span class="smallipop-hint"/>' );
tooltipSpan.append( generatePopupHtml1( errors, newValue[1] ) );
var innerHtml = $('<div id="' + canvas.id +'"></div>');
innerHtml.append('<strong>' + newValue[1] + '</strong>' );
innerHtml.append( tooltipSpan );
$('#' + canvas.id).append(innerHtml);
}, true )
控制台中出现错误
Uncaught TypeError: Cannot read property 'options' of undefinedjquery.smallipop.min.js:11 cbjquery.js:4430 jQuery.event.dispatchjquery.js:4116 jQuery.event.add.elemData.handle
我以前从未使用过jquery,所以我不确定我是否遗漏了一些简单的点。谢谢!
最终剪辑(有效的)
var suppressKey = function( user, key ) {
console.log( "Clicked on the suppress link >>>>> " + user + " " + key );
};
var generatePopupHtml1 = function( errors, exchangeName ) {
var htmlContent = $('<div></div>');
htmlContent.append('<h5 class="panel-danger">' + exchangeName + '</h5>');
var table = $('<table class="table table-bordered table-condensed table-hover"></table>');
for (var index in errors) {
var url = generateCacheDumpUrl(errors[index].id);
table.append('<tr class="warning font-colour mdd-font-size">')
.append('<td><a href="' + url + '" target="_blank">' + errors[index].id + '</a></td>')
.append( '<td><a href=\"#\"' + 'id=\"' + errors[index].id + '\">Suppress</a></td>')
.bind("click", { id: errors[index].id }, function(event) {
var data = event.data;
console.log( "Clicked on suppresskey " + data.id );
suppressKey( 'droy', data.id );
});
}
htmlContent.append(table);
return htmlContent;
}
最佳答案
您的 suppressKey
函数无法从您的表访问,因为该事件未绑定(bind)到您的 anchor 元素。
更改您的 vargeneratePoppHtml
函数,通过创建实际元素而不是像这样使用字符串连接来构建表格:
var htmlContent = $('<div></div>');
htmlContent.append('<h5 class="panel-danger">' + exchangeName + '</h5>');
var table = $('<table class="table table-bordered table-condensed table-hover" style="display=none">');
for (var index in errors) {
var row = $("<tr></tr>")
.append("<td></td>")
.append("<a href='#'>Suppress</a>");
row.find("a").bind("click", function () {
console.log("bound event");
});
table.append(row);
}
htmlContent.append(table);
return htmlContent;
一个快速修复方法是使用点击事件包装您的表格 html 和 .bind
anchor 标记。
return $(html_content).find("a").bind("click", function () {
console.log("Clicked on the suppress link");
});
关于javascript - 无法在指令内的弹出窗口中触发 onclick 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28810124/
我通过 spring ioc 编写了一些 Rest 应用程序。但我无法解决这个问题。这是我的异常(exception): org.springframework.beans.factory.BeanC
我对 TestNG、Spring 框架等完全陌生,我正在尝试使用注释 @Value通过 @Configuration 访问配置文件注释。 我在这里想要实现的目标是让控制台从配置文件中写出“hi”,通过
为此工作了几个小时。我完全被难住了。 这是 CS113 的实验室。 如果用户在程序(二进制计算器)结束时选择继续,我们需要使用 goto 语句来到达程序的顶部。 但是,我们还需要释放所有分配的内存。
我正在尝试使用 ffmpeg 库构建一个小的 C 程序。但是我什至无法使用 avformat_open_input() 打开音频文件设置检查错误代码的函数后,我得到以下输出: Error code:
使用 Spring Initializer 创建一个简单的 Spring boot。我只在可用选项下选择 DevTools。 创建项目后,无需对其进行任何更改,即可正常运行程序。 现在,当我尝试在项目
所以我只是在 Mac OS X 中通过 brew 安装了 qt。但是它无法链接它。当我尝试运行 brew link qt 或 brew link --overwrite qt 我得到以下信息: ton
我在提交和 pull 时遇到了问题:在提交的 IDE 中,我看到: warning not all local changes may be shown due to an error: unable
我跑 man gcc | grep "-L" 我明白了 Usage: grep [OPTION]... PATTERN [FILE]... Try `grep --help' for more inf
我有一段代码,旨在接收任何 URL 并将其从网络上撕下来。到目前为止,它运行良好,直到有人给了它这个 URL: http://www.aspensurgical.com/static/images/a
在过去的 5 个小时里,我一直在尝试在我的服务器上设置 WireGuard,但在完成所有设置后,我无法 ping IP 或解析域。 下面是服务器配置 [Interface] Address = 10.
我正在尝试在 GitLab 中 fork 我的一个私有(private)项目,但是当我按下 fork 按钮时,我会收到以下信息: No available namespaces to fork the
我这里遇到了一些问题。我是 node.js 和 Rest API 的新手,但我正在尝试自学。我制作了 REST API,使用 MongoDB 与我的数据库进行通信,我使用 Postman 来测试我的路
下面的代码在控制台中给出以下消息: Uncaught DOMException: Failed to execute 'appendChild' on 'Node': The new child el
我正在尝试调用一个新端点来显示数据,我意识到在上一组有效的数据中,它在数据周围用一对额外的“[]”括号进行控制台,我认为这就是问题是,而新端点不会以我使用数据的方式产生它! 这是 NgFor 失败的原
我正在尝试将我的 Symfony2 应用程序部署到我的 Azure Web 应用程序,但遇到了一些麻烦。 推送到远程时,我在终端中收到以下消息 remote: Updating branch 'mas
Minikube已启动并正在运行,没有任何错误,但是我无法 curl IP。我在这里遵循:https://docs.traefik.io/user-guide/kubernetes/,似乎没有提到关闭
每当我尝试docker组成任何项目时,都会出现以下错误。 我尝试过有和没有sudo 我在这台机器上只有这个问题。我可以在Mac和Amazon WorkSpace上运行相同的容器。 (myslabs)
我正在尝试 pip install stanza 并收到此消息: ERROR: No matching distribution found for torch>=1.3.0 (from stanza
DNS 解析看起来不错,但我无法 ping 我的服务。可能是什么原因? 来自集群中的另一个 Pod: $ ping backend PING backend.default.svc.cluster.l
我正在使用Hibernate 4 + Spring MVC 4当我开始 Apache Tomcat Server 8我收到此错误: Error creating bean with name 'wel
我是一名优秀的程序员,十分优秀!