js对象的读取速度实例详解
短信预约 -IT技能 免费直播动态提醒
1、访问字面量和局部变量最快,而访问数组元素和对象成员相对较慢。访问对象成员时,就像作用域链一样,在原型链上搜索。
2、如果找到的成员在原型链中的位置太深,访问速度就会变慢。
所以要尽量减少对象成员的搜索次数和嵌套深度。
实例
// 进行两次对象成员查找
function hasEitherClass(element, className1, className2) {
return element.className === className1 || element.className === className2;
}
// 优化,如果该变量不会改变,则可以使用局部变量保存查找的内容
function hasEitherClass(element, className1, className2) {
const currentClassName = element.className;
return currentClassName === className1 || currentClassName === className2;
}
内容扩展:
js对象操作性能问题
1 string越长,那么使用str+="xxx"所花的时间将显著增加(近乎指数级别)。
2 对象数组仅仅只有400个元素的时候,对每个元素的属性和方法的访问时间都达到
了每个属性或者方法1/4毫秒!如果一个元素有10个属性,那么对数组的一次遍历,至少需要1秒,恐怖
3 FileSystem的操作,特别是write的操作几乎与要写的字符串长度的平方成正比。
4 不要采用自己定义的方法进行字符串操作,特别是替代和查找,比较;
我对正则式掌握不透,使用自定义函数的时候,发现在上述2)中提到的遍历中,
自定义函数耗费的时间达到了总时间的80%!
到此这篇关于js对象的读取速度实例详解的文章就介绍到这了,更多相关js对象的读取速度内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341