AJAX和DOM的运行经验
程序员文章站
2022-03-25 10:57:11
被ajax中dom的操作郁闷了好几天,今天总算搞明白了,自学就是苦啊,苦的一把鼻涕一把泪的, 把教训些出来,给后来者提个醒,老鸟就不要看了。 1.dom中的对x...
被ajax中dom的操作郁闷了好几天,今天总算搞明白了,自学就是苦啊,苦的一把鼻涕一把泪的,
把教训些出来,给后来者提个醒,老鸟就不要看了。
1.dom中的对xml的操作不要和浏览器中的弄混掉了,比如getelementbyname是浏览器中内置document对象的dom操作,你用来操作
responsexml就是错误的.在浏览器中,你可以使用document.getelementsbyname('tagname')[0].value来获取控件值,但是在操作
responsexml的时候你就必须使用getelementsbyname('tagname')[0].firstchild.data (nodevalue一样)。
2.如果你要应用responsexml,那么你要在服务器的应答服务中写上response.setcontenttype("text/xml");
假如你的ajax的代码没有一次通过,那么即使在你更改正确后,页面也许还是错误的,这个是讨厌的浏览器缓存造成的,
万恶的缓存,我在这上面耽搁了至少1整天
所以你最好在服务器应答页面写上禁止缓存的语句 response.setheader("cache-control","no-cache");
(请求url后面+当前系统的毫秒数也是一种方法。在js中用new date().gettime()来获取系统与某一特定时间的毫秒差额。).
3.因为当前ie的一些标准不完全符合w3c。例如:
监视控件的改变我们都知道onchange事件,但是对于text控件ie是不支持onchange属性的,所幸我们
onpropertychange事件来监听text。
再如我们在除ie以外的浏览器中设置css属性可以使用setatrribute(),但是在ie中不支持,同样我们使用
eobj.style.stylearrtibute=value来实现。
把教训些出来,给后来者提个醒,老鸟就不要看了。
1.dom中的对xml的操作不要和浏览器中的弄混掉了,比如getelementbyname是浏览器中内置document对象的dom操作,你用来操作
responsexml就是错误的.在浏览器中,你可以使用document.getelementsbyname('tagname')[0].value来获取控件值,但是在操作
responsexml的时候你就必须使用getelementsbyname('tagname')[0].firstchild.data (nodevalue一样)。
2.如果你要应用responsexml,那么你要在服务器的应答服务中写上response.setcontenttype("text/xml");
假如你的ajax的代码没有一次通过,那么即使在你更改正确后,页面也许还是错误的,这个是讨厌的浏览器缓存造成的,
万恶的缓存,我在这上面耽搁了至少1整天
所以你最好在服务器应答页面写上禁止缓存的语句 response.setheader("cache-control","no-cache");
(请求url后面+当前系统的毫秒数也是一种方法。在js中用new date().gettime()来获取系统与某一特定时间的毫秒差额。).
3.因为当前ie的一些标准不完全符合w3c。例如:
监视控件的改变我们都知道onchange事件,但是对于text控件ie是不支持onchange属性的,所幸我们
onpropertychange事件来监听text。
再如我们在除ie以外的浏览器中设置css属性可以使用setatrribute(),但是在ie中不支持,同样我们使用
eobj.style.stylearrtibute=value来实现。