JavaScript 简介
JavaScript 是互联网上最流行的脚本语言,这门语言可用于 HTML 和 web,更可广泛用于服务器、PC、笔记本电脑、平板电脑和智能手机等设备。
JavaScript 是脚本语言
JavaScript 是一种轻量级的编程语言。
JavaScript 是可插入 HTML 页面的编程代码。
JavaScript 插入 HTML 页面后,可由所有的现代浏览器执行。
JavaScript 很容易学习。
您将学到什么
下面是您将在本教程中学到的主要内容。
JavaScript:直接写入 HTML 输出流
您只能在 HTML 输出中使用 document.write。如果您在文档加载后使用该方法,会覆盖整个文档。 |
JavaScript:对事件的反应
alert() 函数在 JavaScript 中并不常用,但它对于代码测试非常方便。
onclick 事件只是您即将在本教程中学到的众多事件之一。
JavaScript:改变 HTML 内容
使用 JavaScript 来处理 HTML 内容是非常强大的功能。
您会经常看到 document.getElementById("some id")。这个方法是 HTML DOM 中定义的。
DOM (Document Object Model)(文档对象模型)是用于访问 HTML 元素的正式 W3C 标准。
您将在本教程的多个章节中学到有关 HTML DOM 的知识。
JavaScript:改变 HTML 图像
本例会动态地改变 HTML <image> 的来源(src):
点亮灯泡
点击以下灯泡查看效果:
点击灯泡就可以打开或关闭这盏灯
尝试一下 »
以上实例中代码 element.src.match("bulbon") 的作用意思是:检索 <img id="myimage" onclick="changeImage()" src="/images/pic_bulboff.gif" width="100" height="180"> 里面 src 属性的值有没有包含 bulbon 这个字符串,如果存在字符串 bulbon,图片 src 更新为 bulboff.gif,若匹配不到 bulbon 字符串,src 则更新为 bulbon.gif
JavaScript 能够改变任意 HTML 元素的大多数属性,而不仅仅是图片。
JavaScript:改变 HTML 样式
改变 HTML 元素的样式,属于改变 HTML 属性的变种。
JavaScript:验证输入
JavaScript 常用于验证用户的输入。
以上实例只是普通的验证,如果要在生产环境中使用,需要严格判断,如果输入的空格,或者连续空格 isNaN 是判别不出来的。可以添加正则来判断(后续章节会说明):
您知道吗?
JavaScript 与 Java 是两种完全不同的语言,无论在概念上还是设计上。 Java(由 Sun 发明)是更复杂的编程语言。 ECMA-262 是 JavaScript 标准的官方名称。 JavaScript 由 Brendan Eich 发明。它于 1995 年出现在 Netscape 中(该浏览器已停止更新),并于 1997 年被 ECMA(一个标准协会)采纳。 |
ECMAScript 版本
JavaScript 已经由 ECMA(欧洲电脑制造商协会)通过 ECMAScript 实现语言的标准化。
年份 | 名称 | 描述 |
---|---|---|
1997 | ECMAScript 1 | 第一个版本 |
1998 | ECMAScript 2 | 版本变更 |
1999 | ECMAScript 3 | 添加正则表达式 添加 try/catch |
ECMAScript 4 | 没有发布 | |
2009 | ECMAScript 5 | 添加 "strict mode",严格模式 添加 JSON 支持 |
2011 | ECMAScript 5.1 | 版本变更 |
2015 | ECMAScript 6 | 添加类和模块 |
2016 | ECMAScript 7 | 增加指数运算符 (**) 增加 Array.prototype.includes |
ECMAScript 6 也称为 ECMAScript 2015。
ECMAScript 7 也称为 ECMAScript 2016。
ZYiDa
468***[email protected]
关于上面切换图片的例子,用三目运算比较简洁。
尝试一下 »
ZYiDa
468***[email protected]
千羽
488***[email protected]
我让楼上的更简洁:
千羽
488***[email protected]
IT攻城狮
sof***[email protected]
还有比我更简洁的吗:
IT攻城狮
sof***[email protected]
StarCat
xin***[email protected]
接楼上@IT攻城狮。
在这段代码中,~function(e){...}(this) 表示使用了一个自执行的匿名函数(Immediately Invoked Function Expression,IIFE)。这个匿名函数接收一个参数 e,表示当前被点击的图片元素,然后对这个元素的 src 属性进行修改,实现灯泡的打开和关闭。
具体来说,当用户点击图片时,onclick 事件会触发,并将当前的图片元素作为参数传递给匿名函数。匿名函数中的代码会通过正则表达式判断当前图片的路径中是否包含 bulboff,如果包含,则将路径修改为 /images/pic_bulbon.gif,否则将路径修改为 /images/pic_bulboff.gif。这样就实现了灯泡的打开和关闭,用户可以通过点击图片来切换灯泡的状态。
需要注意的是,~function(e){...}(this) 中的波浪线 ~ 并不是必须的,它的作用是将匿名函数转换为一个表达式,从而避免将 function 关键字视为一个语句而出现语法错误。因此,这个波浪线可以省略,代码也可以写成 (function(e){...})(this) 的形式,效果是一样的。
StarCat
xin***[email protected]