我们的大脑有逻辑,程序也有逻辑,只要一切都刚刚好,那么我们大脑的逻辑和程序的逻辑是没有冲突的;但是,有时候,我们想当然,只顾自己头脑中的逻辑,而随意臆想程序的逻辑,这个时候,就会有很多我们觉得不可思议的事情发生了。这篇文章的例子是一个同事问我的问题,他说自己程序有问题,他不知道为什么会这样。

这是代码,它原本的意图是通过遍历a数组,根据pid的不同,生成省份和城市对应的联动下拉, 但是,它是有问题的,你可以试着快速浏览下,看看是否能够瞬间找到问题所在:

var a = [
{'id':'1','pid':'0','name':'陕西省'},
{'id':'2','pid':'0','name':'四川'},
{'id':'3','pid':'1','name':'咸阳市'},
{'id':'4','pid':'1','name':'宝鸡'},
{'id':'5','pid':'0','name':'重庆'},
{'id':'6','pid':'2','name':'成都'}
];
for(var i in a){
if(a[i].pid == 0){
var div = $('<div></div>');
div.addClass('accordion-group');
div.html('<div class="accordion-heading">'+
'<a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion" href=" '+a[i].id+'"><i class="glyphicon glyphicon-plus"></i>'+a[i].name+'</a >'+
'</div><div id="collapse'+a[i].id+'" class="accordion-body collapse" style="height: 0px; "><div class="accordion-inner"></div></div>');
for(var j in a){
if(a[j].pid == a[i].id){
console.log(a[j].name);
var div2 = $('<div></div>');
div2.html('<input type="radio" name="area" value="'+a[j].name+'" id="'+a[j].id+'"/><span>'+a[j].name+'</span>');
div2.appendTo('.accordion-inner');
}
}
}
div.appendTo('#accordion2');
}

我先简单理一下他的思路:

1,他是想整个省市联动都是动态生成的,最后,把这个块扔到页面中显示。

2,他希望生成省份的同时就把城市子项添加到省份下面。

再看看他实现时的思路:

1,遍历,动态生成省份元素。注意:此时,它还是个对象,没有容身之处,只存在于代码中,并没有被放到dom中。

2,当遍历一个省份时,再寻找与它对应的城市列表,然后,添加到城市下。但是,注意,他使用的是类名选择,这种选择方式只能选择已经存在于dom节点中的元素。而此时,刚刚生成的省份节点还未添加到页面中。所以,这一次的添加是失败的,因为没有选到任何东西。

在思考的过程中,忽视了程序的基本规则,所以会有不可思议的表现。

var a = [
{'id':'1','pid':'0','name':'陕西省'},
{'id':'2','pid':'0','name':'四川'},
{'id':'3','pid':'1','name':'咸阳市'},
{'id':'4','pid':'1','name':'宝鸡'},
{'id':'5','pid':'0','name':'重庆'},
{'id':'6','pid':'2','name':'成都'}
];
for(var i in a){
if(a[i].pid == 0){//当pid为0时代表个元素是省份,生成省份信息
var div = $('<div></div>');
div.addClass('accordion-group');
div.html('<div class="accordion-heading">'+
'<a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion" href=" '+a[i].id+'"><i class="glyphicon glyphicon-plus"></i>'+a[i].name+'</a >'+
'</div><div id="collapse'+a[i].id+'" class="accordion-body collapse" style="height: 0px; "><div class="accordion-inner"></div></div>');
for(var j in a){//在生成一条省份信息的时候,查询该省份对应的城市元素,遍历生成城市信息,然后放到对应的省份下
if(a[j].pid == a[i].id){
console.log(a[j].name);
var div2 = $('<div></div>');
div2.html('<input type="radio" name="area" value="'+a[j].name+'" id="'+a[j].id+'"/><span>'+a[j].name+'</span>');
div2.appendTo('.accordion-inner');//放到对应省份的子项里面,注意,此时,这个城市对应的省份元素是还未被插入到页面中的,也就是说页面中是没有这个元素的。
}
}
}
div.appendTo('#accordion2');//到这里省份信息才填充到页面中,也就是说页面中才有省份信息,所以第一遍循环里面,对应元素是获取不到的。所以,在第一次加载的时候是获取不到省份下面的城市信息的,当加载一次的基础上,再次执行才可以取到城市信息。
}

突然想起来我的博客名,喜欢的事认真去做,其实,喜欢的人和东西也要认真去了解。懂得了,才能更好的相处!加油吧,小小小喽啰O(∩_∩)O~

顺序或者说优先级的重要性---解决dom生成问题有感的更多相关文章

  1. CentOS6.0(64位)安装Apache+PHP+Mysql教程,安装Magento(解决DOM,Mcrypt,GD问题)完整教程

    CentOS6.0(64位)安装Apache+PHP+Mysql教程,安装Magento(解决DOM,Mcrypt,GD问题)完整教程 0   Posted by :小黑 On : 2012 年 9 ...

  2. 给DOM生成的元素添加事件

    问题:通过js给页面添加新元素,并给该元素添加绑定事件,但新添加的元素上却没有绑定任何事件. 常见例子:在处理表格的时候,每行行末有个删除按钮,如下图.点击删除按钮的时候删除这一行. //html部分 ...

  3. android之DOM生成与解析

    DOM解析不适合于进行大数据文件的操作,DOM解析适合于对文件进行修改和随机存取的操作. DOM生成 //判断一下是否存在sdcard if(!Environment.getExternalStora ...

  4. DOM生成XML文档与解析XML文档(JUNIT测试)

    package cn.liuning.test; import java.io.File; import java.io.IOException; import javax.xml.parsers.D ...

  5. Android使用DOM生成和输出XML格式数据

    Android使用DOM生成和输出XML格式数据 本文主要简单解说怎样使用DOM生成和输出XML数据. 1. 生成和输出XML数据 代码及凝视例如以下: try { DocumentBuilderFa ...

  6. DOM生成&解析

    开篇注意,由于解析有可能有大文件非常耗时,建议另开一个线程解析也可以不开具体视情况而定     DOM生成 1.拿到Document的工厂实例化 DocumentBuilderFactory df = ...

  7. Python:Dom生成XML文件(写XML)

    http://www.ourunix.org/post/327.html 在python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文 ...

  8. 解决 unity 生成 android apk read Resources

    http://www.cnblogs.com/solq/archive/2012/05/21/2511522.html TextAsset t = (TextAsset)Resources.Load( ...

  9. 利用享元模式来解决DOM元素过多导致的网页解析慢、卡死的问题

    我也不知道应该为本文的思路取一个什么比较恰当的标题,但是感觉符合享元模式的思路. 在一些网页应用中,有时会碰到一个超级巨大的列表,成千上万行,这时大部份浏览器解析起来就非常痛苦了(有可能直接卡死). ...

随机推荐

  1. 利用CSS3制作网页动画

    如何在网页中实现动画效果动态图片 flashjavascriptcss3变形是一些效果的集合如平移 旋转 缩放 倾斜效果每个效果都可以称为变形(transfrom) 它们可以分别操控元素发生平移.旋转 ...

  2. geotrellis使用(三十六)瓦片入库更新图层

    前言 Geotrellis 是针对大数据量栅格数据进行分布式空间计算的框架,这一点毋庸置疑,并且无论采取何种操作,其实都是先将大块的数据切割成一定大小的小数据(专业术语为瓦片),这是分治的思想,也是分 ...

  3. tomcat超时、内存不足

    1.Tomcat 启动超过45s启动失败,报超时错误 可以Eclipse 下Tomcat中扩大tomcat启动时间,默认为45 ,修改为245 2 . tomcat启动内存不足 Run - Run C ...

  4. c语言函数作业

    一.PTA实验作业 6-3 使用函数判断完全平方数 1. 本题PTA提交列表 2. 设计思路 1.利用由题目给定的int IsSquare( int n )进行操作 2.首先判断n是否大于0. 3.若 ...

  5. 1013团队alpha冲刺日志集合帖

    alpha冲刺day1 alpha冲刺day2 alpha冲刺day3 alpha冲刺day4 alpha冲刺day5 alpha冲刺day6 alpha冲刺day7 alpha冲刺day8 alph ...

  6. 实现mypwd

    1 学习pwd命令 2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 3 实现mypwd 4 测试mypwd 提交过程博客的链接 代码如图

  7. 201421123042 《Java程序设计》第10周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. 2. 书面作业 本次PTA作业题集异常 1. 常用异常 结合题集题目7-1回答 1.1 自己以前编写的代码中经常出现 ...

  8. Scala Option类型

    转载自: Scala 初学者指南, 这里有一系列很棒的文章 类型 Option 可能你已经见过它在 Map API 中的使用:在实现自己的提取器时,我们也用过它, 然而,它还需要更多的解释. 你可能会 ...

  9. JAVA_SE基础——19.数组的定义

    数组是一组相关数据的集合,数组按照使用可以分为一维数组.二维数组.多维数组 本章先讲一维数组 不同点: 不使用数组定义100个整形变量:int1,int2,int3;;;;;; 使用数组定义 int ...

  10. bootstrap的ajax提交

    一般后台界面都用bootstrap框架,这是一个css框架,里面封装了ajax方法,只需要在样式中指定就行,根本自己不用写 <td> <eq name='item.status' v ...