位置: 编程技术 - 正文

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用法)

  • 逾期未申报是什么意思
  • 房地产企业环保税什么时候申报
  • 个税退回怎么申请
  • 公司老板有钱吗
  • 投标成交服务费
  • 进口环节增值税由海关征收吗
  • 土地成本包含什么
  • 企业所得税税率
  • 预缴增值税城建怎么算
  • 出口专用发票应在哪里开
  • 现金支票填写注意事项有哪些
  • 股息红利纳税地点
  • 购买商标属于什么费用
  • 非货币性资产交换的会计处理
  • 预缴税款的附加税可以抵扣吗
  • 个人所得税征收标准2023
  • 研发部门的办公费属于研发费的哪个类别
  • 电子税务局哪里打印发票
  • 长期未收回的应收账款企业所得税
  • 跨境电子商务零售进口商品的单次交易限值
  • 什么原因导致血脂高
  • 电脑输入法切换键怎么设置
  • 公司清理固定资产怎么开票
  • 一般纳税人销售二手车增值税税率
  • redis使用php
  • 新浪怎么样了
  • win7如何禁用wifi
  • 解决办法总比困难多
  • php pulsar
  • el-table-column formatter
  • php实现计算百度百科
  • 支付属于借方吗?
  • php 文件系统
  • 增值税专用发票怎么开
  • vue2.0安装
  • vmware17虚拟机安装教程
  • 数学建模三个人谁最难
  • python中strftime用法
  • 金税盘一定要交费吗
  • 网上学电脑
  • 非货币性资产交换
  • 帝国cms移动端
  • python如何建立函数
  • 税务局退回来的钱账务处理
  • 金税四期来了我们前期要准备什么
  • 工程奖金计入什么科目
  • 汇算清缴后取得上一年发票
  • 加盟费摊销会计分录
  • 挂靠建筑公司企业所得税怎么交?
  • 建筑行业挂靠代扣税款如何入账?
  • 门面转让费做账怎么做
  • 贷款罚息会计分录
  • 过路费纸质发票可以抵扣增值税吗
  • 没收到发票怎么入账
  • 接受捐赠收入如何计入收入
  • 递延所得税与递延所得税费用
  • 房地产会计如何报税
  • ubuntu14.04安装vim
  • Mac如何使用clash上外网
  • u盘安装启动盘
  • 苹果MAC电脑怎么砸壳应用app
  • xp系统的cad
  • 电脑连不上网怎么回事 笔记本
  • mac上safari
  • opengl learning中文
  • 你所知道的三维建模软件有哪些?
  • 生成器作用
  • jquery的css方法
  • Spring+MyBatis+Velocity+BootStrap实现Android混合App快速高效服务端
  • android系统介绍
  • 批处理设置ip地址配置的dns
  • unity中time.deltatime
  • jquery跳出方法
  • jquery下拉列表
  • jQuery给div,Span, a ,button, radio 赋值与取值
  • 深圳地税局地址工作时间
  • shell ftp -n
  • 广东省地方税务局电子办税服务厅
  • 忘记了密码怎么打开手机
  • 如何做好巡察组组员
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设