欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年JavaScript开发者经常忽略或误用的个知识点 .pdf

    • 资源ID:27264949       资源大小:78.02KB        全文页数:4页
    • 资源格式: PDF        下载积分:4.3金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要4.3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    2022年JavaScript开发者经常忽略或误用的个知识点 .pdf

    JavaScript开发者经常忽略或误用的7 个知识点JavaScript 本身可以算是一门简单的语言,但我们也不断用智慧和灵活的模式来改进它。昨天我们将这些模式应用到了JavaScript 框架中, 今天这些框架又驱动了我们的Web 应用程序。很多新手开发者被各种强大的JavaScript 框架吸引进来,但他们却忽略了框架身后浩如星海的JavaScript 实用技巧。本文将为你呈献其中7 个基础知识点。1. 在 String.prototype.replace 方法中使用/g 和 /i 标志位令很多JavaScript 初学者意外的是,字符串的replace 方法并不会替换所有匹配的子串 而仅仅替换第一次匹配。当然JavaScript 老手们都知道这里可以使用正则表达式,并且需要加上一个全局标志位(/g) :Javascript代码1./ Mistake2./ 踩到坑了3.var str = David is an Arsenal fan, which means David is great; 4.str.replace(David, Darren); / Darren is an Arsenal fan, which means David is great5.6./ Desired7./ 符合预期8.str.replace(/David/g, Darren); / Darren is an Arsenal fan, which means Darren is great另一个基本的逻辑错误就是在大小写不敏感的校验场合(字母可大写可小写)没有忽略大小写,此时/i 标志位就很实用:Javascript代码1.str.replace(/david/gi, Darren); / Darren will always be an Arsenal fan, which means Darren will always be great(译注:上面这段例程我没有看懂用意,可能是注释有误吧 )每个JavaScript 开发者都曾踩过这两个标志位的坑 因此别忘了在适当的时候用上它们!2. 类数组对象和Array.prototype.slice 方法数组的slice 方法通常用来从一个数组中抽取片断。但很多开发者不了解的是,这个方法还可以用来将 “ 类数组 ” 元素(比如arguments 参数列表、节点列表和属性列表)转换成真正的 数 组 :( 译 注 : DOM 元 素 的 属 性 列 表 通 过attributes属 性 获 取 , 比 如document.body.attributes。 )Javascript代码1.var nodesArr = Array.prototype.slice.call(document.querySelectorAll(div); 2./ true array of DIVs3./ 得到一个由 div 元素组成的 “ 真正的 ” 数组名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 4 页 - - - - - - - - - 4.5.var argsArr = Array.prototype.slice.call(arguments); 6./ changes arguments to true array7./ 把 arguments 转换成一个 “ 真正的 ” 数组8.你还可以使用一次简单的 slice 调用来克隆一个数组:9.var clone = myArray.slice(0); / naive clone10./ 浅克隆(译注:这里的参数0 也可以省略,我估计undefined 被 slice 方法自动转换为0 了吧。 )Array.prototype.slice 绝对是JavaScript 世界中的一玫珍宝, 但 JavaScript 初学者们显然还没有意识到它的全部潜力。3. Array.prototype.sort 方法数组的sort 方法 远远没有被充分利用,而且可能比开发者们想像的更加强大。很多开发者可能觉得sort 方法可以用来做这种事情:Javascript代码1.1, 3, 9, 2.sort(); 2./ Returns: 1, 2, 3, 93./ 返回 1, 2, 3, 9 这没错,但它还有更强大的用法,比如这样:Javascript代码1. 2. name: Robin Van PurseStrings, age: 30 , 3. name: Theo Walcott, age: 24 , 4. name: Bacary Sagna, age: 28 5.sort(function(obj1, obj2) 6./ Ascending: first age less than the previous7./ 实现增序排列:前者的 age 小于后者8.return obj1.age - obj2.age; 9.); 10./ Returns: 11./ 12./ name: Theo Walcott, age: 24 ,13./ name: Bacary Sagna, age: 28 ,14./ name: Robin Van PurseStrings, age: 30 15./ 你不仅可以对简单类型的数组项进行排序,可以通过属性来排序对象。如果哪天服务器端发来一段JSON 数据,而且其中的对象需要排序,你可别忘了这一招!4. 用 length 属性来截断数组几乎所有开发者都踩过JavaScript 的这个坑 “ 传对象只是传引用” 。开发者们经常会试名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 4 页 - - - - - - - - - 图 把一个数组清空,但实际上却错误地创建了一个新数组。Javascript代码1.var myArray = yourArray = 1, 2, 3; 2.3./ :(4./ 囧5.myArray = ; / yourArray is still 1, 2, 36./ yourArray 仍然是 1, 2, 37.8./ The right way, keeping reference9./ 正确的方法是保持引用10.myArray.length = 0; / yourArray and myArray both 11./ yourArray 和 myArray(以及其它所有对这个数组的引用)都变成 了坑里的人们终于明白,原来传对象只是在传引用。因此当我把myArray 重新赋值为 时,确实会创建出一个新的空数组,但其它对老数组的引用仍然没变!大坑啊! 还是换用截断的方法吧,少年。5. 使用push 来合并数组在上面的第2 节里,我展示了数组的slice 和 apply 方法所能组合出的几个小妙招,所以对于数组方法的其它技巧,你应该已经做好心理准备了吧。这次我们使用push 方法来合并数组:Javascript代码1.var mergeTo = 4,5,6; 2.var mergeFrom = 7,8,9; 3.4.Array.prototype.push.apply(mergeTo, mergeFrom); 5.6.mergeTo; / is: 4, 5, 6, 7, 8, 9这是一项不为人知的小技巧,简单的原生方法就可以实现数组合并这样的常见任务。(译注:这个方法的巧妙之外不仅在于push 方法可以接收多个参数,还涉及到apply 方法的第二个参数的用法。 )6. 高效探测功能特性和对象属性很多时候开发者们会像下面这样来探测浏览器的某个特性:Javascript代码1.if (navigator.geolocation) 2./ Do some stuff3./ 在这里干点事情4. 当然这可以正常工作,但它并不一定有很好的效率。因为这个对象探测方法会在浏览器中初名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 4 页 - - - - - - - - - 始化资源。 在过去, 上面的代码片断可能会在某些浏览器下导致内存泄露。更好、 更快的方法是检查对象是否包含某个键名:Javascript代码1.if ( geolocationin navigator) 2./ Do some stuff3./ 在这里干点事情4. 键名检查十分简单,而且可以避免内存泄露。另外请注意,如果这个属性的值是假值,那么前一种探测方式将会得到“ 否” 的结果,并不能真正探测出这个键名是否存在。7. 事件对象的preventDefault 和 stopPropagation 方法很多时候,当一个动作元素(比如链接)被点击时,会触发某个功能。显然我们并不希望点击 链接 时浏 览器 顺着 这个 链接 跳转 ,于 是我 们会 习惯 性地 使用JavaScript 类库的Event.stop 方法:Javascript代码1.$( a.trigger).on(click, function(e) 2. e.stop(); 3.4./ Do more stuff5./ 在这里干点事情6.); (译注:不知道哪个类库有这个方法,估计其作用相当于return false; 吧。语法看起来像jQuery , 但jQuery 并 没 有 这 个 方 法 , 而 且jQuery 是 支 持e.preventDefault 和e.stopPropagation 方法的。)这个懒方法有一个问题,它不仅阻止了浏览器的默认动作,同时也阻止了事件继续冒泡。这意味着元素上绑定的其它事件监听器将不会被触发,因为它们根本就不知道有事件发生。此时不妨使用preventDefault 吧!JavaScript 老鸟们看到这篇文章可能会说“ 我早知道了 ” ,但说不定什么时候,他们就会在某一点上栽跟头。提醒大家留意JavaScript 中的各种小细节,失之毫厘谬以千里啊!名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 4 页 - - - - - - - - -

    注意事项

    本文(2022年JavaScript开发者经常忽略或误用的个知识点 .pdf)为本站会员(Che****ry)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开