摘要:先讨论JavaScript的由来和一些比较容易混淆的概念,又讨论了JavaScript的实现,紧接着说明了在网页中怎么有效地更好地引入js代码。

JavaScript的由来

是从一个简单的输入验证器变成的一门强大的解释型编程语言。

JavaScript和Java关系不大。Java 和Javascript是雷锋和雷峰塔的关系。(来自佚名的《JS继承机制》的故事)

JavaScript、JScript和ECMAScript的关系

JavaScript 和JScript的关系一定程度上类似于Java和C#的关系,不同的是Javascript和JScript部分相兼容。

ECMAScript是欧洲计算机制造商协会(ECMA) 联合一些公司的程序员一起制定的脚本语言的标准。

JavaScript的实现

JavaScript的实现由下列三个不同的部分组成:

  • 核心:ECMAScript   由ECMA-262定义,提供核心语言功能
  • 文档对象模型:DOM  提供访问和操作网页内容的方法和接口
  • 浏览器对象模型:BOM  提供与浏览器交互的方法和接口

(1)ECMAScript与Web浏览器没有依赖关系,本身不包含输入和输出定义。

ECMAScript的宿主环境包括Web浏览器,Node(一种服务端JavaScript平台)和Adobe Flash。

宿主环境不仅提供基本的ECMAScript实现,也提供了该语言的扩展,以便语言与环境之间进行交互。(Web浏览器提供的就是DOM)

(2)DOM是针对XML但经过扩展用于HTML的应用程序编程接口(API).

DOM把整个页面映射成一个多层节点结构。

(3)BOM提供与浏览器交互的方法和接口。



JavaScript的使用

<script>元素负责引入JavaScript代码。

有两种引入方式:(不做举例,详细参考w3school里的讲解)

  • 直接在<script>标签内写JavaScript代码。
  • 编写JavaScript代码,并保存成独立的js文件,引入到页面中。

尽可能使用外部文件来包含JavaScript代码。 可维护性,可缓存,适应未来。。

该元素有六个属性:

  • async:可选(只对外部脚本文件有效)。表示应该立即下载脚本(但延迟执行),但不妨碍页面中的其他操作,不保证按照指定的先后顺序执行。
    比如下载其他资源,或者等待加载其他脚本。目的是不让页面等待两个脚本下载和执行。这种情况下保持各个脚本的互不依赖很重要。
  • charset: 可选(很少用)。 表示通过src属性指定的代码的字符集。大多数浏览器会忽视该属性。
  • defer:可选(只对外部脚本有效)。 表示脚本可以延迟到文档完全被解析和显示之后执行。脚本执行时要求得按照顺序执行,但实际中不一定。
  • language:(已废弃)会被浏览器忽视。
  • src:可选。表示包含要执行代码的外部文件。
  • type:可选(language属性的替代品),表示编写代码使用的脚本语言的内容类型(MIME类型)。text/javascript(这个也是默认值)。

一些我不太注意的知识点:

只要不存在defer和async属性,在解释器对<script>元素内部的所有代码求值完毕前(包括下载外部代码文件时),

页面中的其余内容都不会被浏览器加载。

带有src属性的<script>标签之间不应该包含额外的Js代码,只会下载并执行外部脚本文件,而忽略嵌入的代码。

<script> 标签的位置

(1) 传统做法,所有<script>元素都应该放在<head>元素中。

意味着必须等到全部JavaScript代码都被下载、解析和执行完成后,才开始呈现页面的内容(浏览器在遇到<body>才开始呈现内容)。

问题:JS代码很多,很大。则网站体验就囧了。

解决方法,参见(2)

(2)  现代的做法,把全部JavaScript引用放在<body>元素中页面内容的后面。

Javascript的简介和使用的更多相关文章

  1. JavaScript面向对象简介

    JavaScript面向对象简介 @(编程) [TOC] 1. 命名空间 命名空间是一个容器,它允许开发人员在一个独特的,特定于应用程序的名称下捆绑所有的功能. 在JavaScript中,命名空间只是 ...

  2. 【JavaScript】简介、<Script>标签及基本概念

    一.前言 时光荏苒,岁月匆匆.今年年初进入数据平台部门转型做Web平台.要想搞好前端肯定要学好JavaScript,于是准备抓上一俩本书从基础学起. 二.内容       简介 JavaScript是 ...

  3. 1. 现代 javascript 用法 简介 及 babel

    简介 包含 ECMAScript 基本概念,babel 使用 ,eslint 使用 以及新语法的介绍 和使用经验 ECMAScript 概念 ECMASctipt 是一种由 Ecma (前身为欧洲计算 ...

  4. Sentry 官方 JavaScript SDK 简介与调试指南

    系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Maps Sentry For ...

  5. JavaScript(一)——简介(简单介绍)

    1.JavaScript是个什么东西? 它是个脚本语言,需要有宿主文件,它的宿主文件是HTML文件. 2.它与Java什么关系? 没有什么直接的联系,Java是Sun公司(已被Oracle收购了),J ...

  6. HTML 学习笔记 JavaScript(简介)

    JavaScript 是世界上最流行的编程语言. 这门语言可用于HTML和web 更可广泛用于服务器.PC.笔记本电脑.平板电脑和智能手机等设备. JavaScript是脚本语言 JavaScript ...

  7. JavaScript: JavaScript的简介和入门代码演示

    1.Javascript的发展历史介绍: javascript是指的实在网页上编写的编程语言,其主要是控制器html的动态显示效果.HTMl能带来的只是一些基本的页面的风格,而要展示的漂亮使用CSS, ...

  8. javascript正则表达式简介

      javascript正则表达式 javascript正则表达式 regular expression是一个描述字符模式的对象: ECMAScript中的RegExp类表示正则表达式: String ...

  9. javascript多线程简介

    讲多线程之前,我们先了解一下JS的事件机制 浏览器运行时,脚本必须定期让位给UI进程进行来维持网页的响应,闲置太长时间的脚本可能会被浏览器当成失控脚本,进而造成假死或弹窗 事件触发的设计javascr ...

  10. Javascript 知识点简介

    如何在HTML中引入JS? 所有重定向的HTML标签内都可以嵌入javascript代码. 浮点数不要用 == 来进行判断 var num=0;    for(var i=0;i<10;i++) ...

随机推荐

  1. jquery 循环显示div的示例代码

    我们用一个语句就让下面五个div显示成功,具体实现如下,感兴趣的朋友可以参考下 直接看例子 复制代码代码如下: for(var p=1; p<=5; p++){  $("#proper ...

  2. mysql存储过程讲解

    1.数据库存储过程:简单滴说,存储过程就是存储在数据库中的一个程序. 2..数据库存储过程作用: 第一:存储过程因为SQL语句已经预编绎过了,因此运行的速度比较快. 第二:存储过程可以接受参数.输出参 ...

  3. linux磁盘设备知识

    linux分区数字编号: 1.分区数字编号1至4留给主分区或扩展分区使用,逻辑分区编号从5开始. 2.IDE硬盘设备名均以/dev/hd开头,不同硬盘编号依次是/dev/hda/./dev/hdb./ ...

  4. RHEL 6.4 64bit kettle5.01导入xlsx格式的excel时报错

    环境:RHEL 6.4 64bit : kettle5.01:xlsx格式的excel 创建的job,在spoon里面运行都没有问题(Linux和windows) 在windows的命令行运行也没有问 ...

  5. 一步步学习ASP.NET MVC3 (2)——入门程序

    请注明转载地址:http://www.cnblogs.com/arhat 在上一节中,我们只是简单的介绍了什么是MVC及MVC的运行原理.而本节呢,主要来实现下一ASP.NET MVC3的开发流程,并 ...

  6. ExtJs Ext.panel.Panel和Ext.container.Viewport布局问题

    Ext.container.Viewport Ext.panel.Panel Viewport 它的布局会占用整个 body,也应该是这样,它会随着浏览器的高度和宽度的变化而变化. Panel 布局时 ...

  7. Portal:十大免费建站程序推荐

    TOP1 独立网店系统 ShopEx,是上海商派网络科技有限公司推出的一个网上商店系列程序.是目前网店软件行业内比较知名的公司.ShopEx旗下的网上商店系统.网上商城系统以及丰富的网商工具,以专业的 ...

  8. java基础知识整理:

    一, Java中的继承: 1. final关键字(最终的,不可修改的不可变化的,可以修饰类,方法,变量等): 如果final修饰类的话,这个类不可以被继承: 如果修饰方法的话,这个方法不可以被子类覆盖 ...

  9. Twitter:蓄水池储水量问题

    早上买了两个饼夹肉,我吃了一个,辣椒粉好多,现在一直在实验室喝水. 一.倒数第n位 今年暑假去世纪佳缘面试,其中一题就是这个,只能遍历一遍链表求出倒数第n位. 答案是两个指针,第一个在头部设为A,第二 ...

  10. 不改变中间层,如何玩转 .NET 的远程处理功能?

    原文链接: https://msdn.microsoft.com/enus/library/aa289846(v=vs.71).aspx Visual Studio .NET 2003 该方案展示了传 ...