今天,我作了这样的事情,就是通过ajax把要一个准备装入下拉框的数组找并一一装入
下拉框中,接着我开始访问他们,把上一次访问的记录呈现出来,但是总是不能正常遍历下拉框的options,无论用children属性还是options属性,得到的length都是1,
怎么回事呢?难道select和options之间的关系比较特殊,要让select识别它下面的options有一个过程,于是我就在select装入options之后,两次打印了option们的长度
第一次alert的结果是在select装入options之后马上打印的,得到的是1,
第二次alert的结果自然有个延时,得到的正确的个数,
于是我得出了如下结论:
select中的option被select识别是有个过程的,不是现装现访问的,必须给个延时,让select有时间的好好消化下给它的option们.
这如同iframe元素创建并添加文档树中时,都会有个冷却时间让父元素去识别它,把它交由document或window的iframe集合管理起来.
如果这是调整一下他们在文档中的位置就没有这个必要了,因为相应的集合中有他们的引用存在,不需要重新识别他们了.
现在用个两句代码来总结:
appendIframeOrOptions();
window.setTimeout('visit()',500);
下拉框中,接着我开始访问他们,把上一次访问的记录呈现出来,但是总是不能正常遍历下拉框的options,无论用children属性还是options属性,得到的length都是1,
怎么回事呢?难道select和options之间的关系比较特殊,要让select识别它下面的options有一个过程,于是我就在select装入options之后,两次打印了option们的长度
第一次alert的结果是在select装入options之后马上打印的,得到的是1,
第二次alert的结果自然有个延时,得到的正确的个数,
于是我得出了如下结论:
select中的option被select识别是有个过程的,不是现装现访问的,必须给个延时,让select有时间的好好消化下给它的option们.
这如同iframe元素创建并添加文档树中时,都会有个冷却时间让父元素去识别它,把它交由document或window的iframe集合管理起来.
如果这是调整一下他们在文档中的位置就没有这个必要了,因为相应的集合中有他们的引用存在,不需要重新识别他们了.
现在用个两句代码来总结:
appendIframeOrOptions();
window.setTimeout('visit()',500);
解决Select选项延迟加载问题
本文探讨了在使用Ajax填充下拉框时遇到的问题:即填充的选项无法立即被正确遍历。通过实验发现,Select元素需要一定的时间来识别新增的选项。文中提供了一个简单的解决方案,确保Select元素能够正确加载所有选项。
7063

被折叠的 条评论
为什么被折叠?



