旧习惯
我 们最常用的简单选择器包括"id选择器"、"类选择器"、"标签选择器",毫无疑问的是id选择器有着最好的速度。这取决于dom内置的函数 getElementById,其次是标签选择器,使用的是dom内置的函数getElementsByTag,最差的是类选择器,其需要通过正则解析 html,并且需要在浏览器内核外递归,这种递归遍历是无法被优化的。
就需求来说,css中选择器是为了通过语义来渲染样式,而jQuery中大 部分情况只是为了选出一类DOMElement,加以同一逻辑的操作。而在"最常用的选择器使用"中,类选择器以13.082%的使用率排在第二位。也就 是说在13.082%的情况下,整个document的html被解析了一遍,并递归到DOM树的叶子节点。这部分无意义的性能损耗令人发指。
我 们最常用的简单选择器包括"id选择器"、"类选择器"、"标签选择器",毫无疑问的是id选择器有着最好的速度。这取决于dom内置的函数 getElementById,其次是标签选择器,使用的是dom内置的函数getElementsByTag,最差的是类选择器,其需要通过正则解析 html,并且需要在浏览器内核外递归,这种递归遍历是无法被优化的。
就需求来说,css中选择器是为了通过语义来渲染样式,而jQuery中大 部分情况只是为了选出一类DOMElement,加以同一逻辑的操作。而在"最常用的选择器使用"中,类选择器以13.082%的使用率排在第二位。也就 是说在13.082%的情况下,整个document的html被解析了一遍,并递归到DOM树的叶子节点。这部分无意义的性能损耗令人发指。