我正在尝试使用 JQuery 将 dataString 传递给 ajax 调用。在调用中,我构造了get参数,然后将它们发送到接收端的php页面。问题在于数据字符串中包含“&”符号,并且 HTML 严格验证器对其进行了阻塞。
这是代码:
$(document).ready(function(){
$("input#email").focus();
$('#login_submit').submit(function(){
var username = $('input#email').val();
var password = $('input#password').val();
var remember = $('input#remember').attr("checked");
var dataString = "email="+username+"&password="+password+"&remember="+remember;
$.post('login.php', dataString, function(data) {
if (data == 'Login Succeeded.') {
location.reload(true);
} else {
$("input#email").focus();
$("#login_msg").html(data).effect("pulsate", {times: 2}, 1000);
}
});
return false;
});
});
这是验证器消息的示例:无法为通用实体“密码”生成系统标识符。
var dataString = "email="+username+"&password="+password+"&remember="+rememb…
(在验证器中,第一个&符号后面的“p”被标记为红色,表示失败点)。
尝试将 JavaScript 放入 CDATA 块中,如下所示:
<script type="text/javascript">
<![CDATA[
// content of your Javascript goes here
]]>
</script>
这应该使它通过验证。为了更加安全,您可以在 CDATA 标签周围添加 Javascript 注释,以对不理解 CDATA 标签的旧浏览器隐藏它们:
<script type="text/javascript">
/* <![CDATA[ */
// content of your Javascript goes here
/* ]]> */
</script>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)