位置: 编程技术 - 正文

W3C Group的JavaScript1.8 新特性介绍

编辑:rootadmin
JavaScript 1.8 计划作为Gecko 1.9(将要合并在Firefox 3中)的一部分开始使用的。比起JavaScript 1.7来说,这只是很小的更新,不过它也确实包含了一些向ECMAScript 4/JavaScript 2进化的痕迹。JavaScript 1.8还将包含在JavaScript 1.6 和 JavaScript 1.7中的所有新特性。 使用 JavaScript 1.8 为了可以在HTML中使用 JavaScript 1.8 的新特性,需要如下这样写: <script type="application/javascript;version=1.8"> ... 你的代码 ... </script> 在使用 JavaScript shell 、JavaScript XPCOM 组件,或者 XUL <script> 元素的时候,就是自动使用最新的JS版本(Mozilla 1.9中的 JS1.8)。 如果需要使用新的关键字 "yield" 和 "let" 的话,你就要指定是1.7版本或者更高的版本,因为已经写好的那些代码可能会把这两个关键字用作变量名或者函数名。如果并没有使用任何新的关键字,就可以不用指定JavaScript的版本。 表达式闭包 这个新添加的特性其实就是简单函数的方便写法,使得这个语言更加类似典型的Lambda notation. JavaScript 1.7 以及更老的版本: function(x) { return x * x; } JavaScript 1.8: function(x) x * x 这个语法允许你省略花括号和 'return' 语句 -- 隐式的做它们的工作。用这种方法写,就只是表面上看起来短了一些,并没有其他好处。 示例: 绑定事件处理器的简单写法: document.addEventListener("click", function() false, true); 把这个定义与JavaScript 1.6中的一写数组函数一起使用: elems.some(function(elem) elem.type == "text"); 生成器表达式 这个新添加的特性,允许你简单的创建生成器(在JavaScript 1.7引入的)。通常你以前需要创建一个自定义的函数,它含有一个 yield,但是这个新特性使你可以使用类似数组概念的语法来创建一个独立的生成器句柄。 在 JavaScript 1.7 中,你可能需要写出想下面这样的代码来为一个对象创建自定义的生成器: function add3(obj) { for ( let i in obj ) yield i + 3; } let it = add3(someObj); try { while (true) { document.write(it.next() + "<br>n"); } } catch (err if err instanceof StopIteration) { document.write("End of record.<br>n"); } 在 JavaScript 1.8 中,你可以规避要重建生成器函数的麻烦,而使用一个生成器表达式来代替: let it = (i + 3 for (i in someObj)); try { while (true) { document.write(it.next() + "<br>n"); } } catch (err if err instanceof StopIteration) { document.write("End of record.<br>n"); } 生成器表达式也可以像数值那样被传给一个函数。非常值得注意的是,生成器在绝对必要的有用的时候才被运行(并不像典型的数组概念的条件那样,预先搭好数组的结构)。这个区别可以从下面的例子中看到: 使用JavaScript 1.7 数组理念 handleResults([ i for ( i in obj ) if ( i > 3 ) ]); function handleResults( results ) { for ( let i in results ) // ... } 使用 JavaScript 1.8 的生成器表达式 handleResults( i for ( i in obj ) if ( i > 3 ) ); function handleResults( results ) { for ( let i in results ) // ... } 这两个例子之间最大的区别就是,使用生成器表达式的时候,只需要循环那个 'obj' 结构一次,总共;而在第一个例子中,将会在递归的时候再循环一次。 JavaScript 1.8.1 JavaScript 1.8.1包含在Gecko1.9.1(将整合到Firefox3.5中)中。该版本只有很少的更新,主要集中在添加实时编译跟踪,参见:Tracemonkey just-in-time compiler。 当然其中较为显著的改变是移除了API中的callback分支,替换了callback操作,参见:detailed in this newsgroup posting。 添加的部分 Object.getPrototypeOf() This new method returns the prototype of a specified object. 该方法将返回指定对象的原型。 New trim methods on the String object The String object now has trim(), trimLeft(), and trimRight() methods. String对象现在将具有trim(),trimLeft(),和trimRight()方法。

推荐整理分享W3C Group的JavaScript1.8 新特性介绍,希望有所帮助,仅作参考,欢迎阅读内容。

W3C Group的JavaScript1.8 新特性介绍

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

scrollTop 用法说明 下面的演示中,外层元素的高度值是px,内层元素的高度值是px。很明显,外层元素中的内容高过了外层元素本身.当向下拖动滚动条时,有部分内容

javascript scrollLeft,scrollWidth,clientWidth,offsetWidth 完全详解 scrollHeight:获取对象的滚动高度。scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离scrollTop:设置或获取位于对象最顶端和窗

DOM 基本方法 直接引用结点1.document.getElementById(id);--在文档里面通过id来找结点2.document.getElementByTagName(tagName);--返回一个数组,包含对这些结点的引用--如:document.getEl

标签: W3C Group的JavaScript1.8 新特性介绍

本文链接地址:https://www.jiuchutong.com/biancheng/382948.html 转载请保留说明!

上一篇:JS backgroundImage控制

下一篇:scrollTop 用法说明(scrollbottom用法)

  • 本期实际抵减税额合计0.00不等于
  • 每月工资不一样怎么交党费
  • 股东投资是所有者权益
  • 出口货物发生退运是征税还是免税
  • 红字发票冲红需要收回原发票吗
  • 印花税购销合同包括哪些
  • 一张发票开不足一台设备的金额怎么办
  • 固定资产减少当月
  • 研发试制的样机属于固定资产吗
  • 土地使用权入账价值
  • 购买固定资产增值税可以抵扣
  • 房产赠与流程是什么意思
  • 工资薪金税前扣除比例
  • 小微企业免征增值税政策2023
  • 从业人数如何计算
  • 个体户开普票要交企业所得税吗
  • 怎么查询财务章备案信息
  • 向分公司拨款如何填现金流量表
  • 如何确定赊销额度
  • 制造费用包括哪些费用项目
  • 出口报关和不报关的区别
  • 临时设施需要验收吗
  • 大额转账人行审核通过
  • 费用化支出含义
  • 内账进项税不设置怎么账务处理
  • 印花税减半征收优惠政策2023
  • 浏览器显示英语怎么设置成中文
  • 关联企业承担什么责任
  • 购入的无形资产
  • 注册资金没有的怎么做账
  • 中央公园商场
  • 损益类账户年末一定无余额对吗
  • 毫米波雷达的硬件构成
  • vue大型项目撑得住吗
  • 加计扣除内容
  • 研发费用算期间费用吗
  • 法定的盈余公积是什么
  • c语音中static
  • 更改sql server数据库名
  • c语言指针妙用
  • 企业成立刻章流程
  • 项目差旅费能计入项目费用吗
  • MYSQL数据库使用教程
  • 下月初可以认证上月的发票么
  • 工业企业外购存货的入账价值一般包括()
  • 装修公司预收款要交增值税吗
  • etc的充值发票可以报账吗
  • 应付账款明细账怎么登记
  • 预缴税款的会计处理
  • 汽车固定资产残值率
  • sql2000 sql2008
  • sqlsever导入数据时出现ole db连接数据无效
  • win10预览版21301bug
  • Win10预览版更新弹窗如何关闭
  • freebsd书籍
  • mac系统怎么清理Adobe残留
  • u盘安装linux系统遇到的问题
  • win7系统360浏览器自启动怎么关闭
  • ubuntu netbook
  • macbookpro4399小游戏
  • mac不小心把硬盘删了怎么办
  • win10专业版怎么调屏幕亮度
  • win10内置杀毒
  • Win10预览版拆弹
  • linux常用桌面环境
  • win10更新总失败
  • 铁嘴李林
  • js获取秒数
  • div如何排版
  • 浅谈python
  • 详解TCP的四种定时器
  • Do All in Cmd Shell一切在命令行下完成第1/6页
  • 批处理实现语音报警
  • 梦见擦窗户框
  • javascript学习指南
  • 使用SQLite数据库保存和处理数据
  • 深圳税务局工作时间表
  • 什么叫税务备案
  • 四川税务app下载安装
  • 2019小规模纳税人标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设