作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 displayTag 表装饰器来显示我的 JSP 页面。
该页面有一个包含列的表格。其中一列是“操作”,其中显示了 2 个超链接。一是工资,二是接近。每行将有 5 列操作,最后一列带有超链接。
这是JSP中的 Action 显示代码
<display-el:column property="action" sortable="false" title=" "
class="defaultTextCentered" style="width:6%" sortName="action" />
下面是我的装饰器代码
public String getAction() {
renderPayLink();
}
private void renderPayLink() {
decoratedVal.append("<a href=\"javascript:newPopup('");
decoratedVal.append(getContextPath());
decoratedVal.append("/abc/taxPaymentInternal.html?iSeqNo=");
decoratedVal.append(abc.getISeqNumber());
decoratedVal.append("&iPeriod=");
decoratedVal.append(abc.getIDate());
decoratedVal.append("', 800, 700)\" title=\"Pay\">Pay</a>");
decoratedVal.append(" ");
}
因此,单击链接时将打开一个弹出窗口,让用户输入一些详细信息并提交。当此弹出窗口打开时,我仍然可以转到主浏览器并再次单击“付款”,这会刷新弹出窗口并使我再次重新提交信息。单击浏览器然后打开弹出窗口后,我必须通过禁用付费按钮来阻止这种情况发生。我怎样才能实现这个目标?
将工资替换为
decoratedVal.append("', 800, 700)\" title=\"Pay\" ");
decoratedVal.append("onclick=\"this.setAttribute(");
decoratedVal.append("\'style\', \'pointer-events:none; cursor:default;\'); this.setAttribute(");
decoratedVal.append("\'href\', \'\')\">Pay</a>");
decoratedVal.append(" ");
从 f12 调试中获取“无法获取未定义或空引用的属性‘setAttribute’”错误。
<a title="Pay" onclick="this.setAttribute('style', 'pointer-events:none; cursor:default;'); this.setAttribute('href', '')" href="javascript:newPopup('/mei/invoicing/launchConfirmPaymentInternal.html?invoiceSeqNo=131946&invoicePeriod=02-11-2017', 800, 700)">Pay</a>
最佳答案
一种方法是禁用 <a>
当您点击它时标记。
您可以替换此行:
decoratedVal.append("', 800, 700)\" title=\"Pay\">Pay</a>");
与那些:
decoratedVal.append("', 800, 700)\" title=\"Pay\")
decoratedVal.append("onclick=\"this.setAttribute(")
decoratedVal.append("\'style\', \'pointer-events:none; cursor:default;\'); this.setAttribute(");
decoratedVal.append("\'href\', \'\')\">Pay</a>");
请注意,该链接将在页面刷新后再次可用。如果您需要其他方式来激活它,则需要手动执行。
如果您有样式表(例如 CSS 文件),您可以在那里创建此类:
.disabledLink{
pointer-events: none;
cursor: default;
}
在onclick
中链接标记的事件,替换 setAttribute
与 addClass('disabledLink')
。这也使得删除变得更容易,使用 removeClass('disabledLink')
关于javascript - 禁用 displayTag 中的超链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56349867/
我是一名优秀的程序员,十分优秀!