你所在位置:首页Javascript开发 → jQuery在异步请求数据返回后,调用$("selector").),不能显示内容的问题解决办法

jQuery在异步请求数据返回后,调用$("selector").),不能显示内容的问题解决办法

发布时间:2019-07-11 这个曾经困扰我了大半天。我出的状况是:
首先说明,我返回的data.content内容是一个页面的html代码。
1.数据能通过jquery中的ajax异步正常返回,alert(data.content);能获取到值。
2.通过$("select").text(data.content);也能显示到页面去。只是因为text方法本身的原因,页面显示的数据是完整的html代码,并不是经过解释后的html代码。所以是不符合要求的。
必须用html()方法来实现。
3.但是通过$("select").html(data.content)来显示返回的数据内容时,就是空白的。什么也没有。
初步判定是因为data.content所返回的内容里面有特殊字符,或者’,“这样的内容。导致了无法正常用html()方法来解析。
期间用过很多的jquery方法,都没用。也尝试用js的replace()和自己扩展replaceAll()方法都没用,当一对这个返回的内容进行js操作,后面的代码就不执行。alert()方法打印都不执行。
这样,那么我就考虑,是不是可以不用jquery来修改页面的内容呢?
于是我用:
document.getElementById("select").innerHTML = data.content;这样一句代码来试试。结果奇迹出现了。呵呵。成功了。
于是,我得出的结论是,jquery内部对于一些字符串的特殊字符当做了错误处理。并不是js对于字符串的特殊字符当做了错误处理。这句话也影响了我的代码调试。因为我记得曾在网上看到有人说js把特殊字符当做了错误处理。但是从我这个问题来看,js似乎并没有这样来处理特殊字符。不过这个结论不能单凭我这么一个问题就成立,希望大家一起讨论,或者你有例子,可以给出证明。大家一起成长进步,谢谢大家。
作者:gayayzy
上一篇:JQuery框架和Ajax的综合使用
下一篇:用jQuery实现返回页面顶部的功能