摘要:先讨论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. Linux procfs详解

    1.0 proc文件系统总览在类Unix系统中体现了一种良好的抽象哲学,就是几乎所有的数据实体都被抽象成一个统一的接口--文件来看待,这样我们就可以用一些简单的基本工具完成大量复杂的操作.在Linux ...

  2. Seven Python Tools All Data Scientists Should Know How to Use

    Seven Python Tools All Data Scientists Should Know How to Use If you’re an aspiring data scientist, ...

  3. 实用make最佳实践

    http://www.cnblogs.com/ggjucheng/archive/2011/12/14/2288055.html 一.前言 Make工具最主要也是最基本的功能就是通过makefile文 ...

  4. MemoryStream类

    转自:http://www.cnblogs.com/kissdodog/archive/2013/01/20/2868864.html MemoryStream 是一个特例,MemoryStream中 ...

  5. 【 NOIP2015 DAY1 T2 信息传递】带权并查集

    题目描述 有n个同学(编号为1到n)正在玩一个信息传递的游戏.在游戏里每人都有一个固定的信息传递对象,其中,编号为i的同学的信息传递对象是编号为Ti同学. 游戏开始时,每人都只知道自己的生日.之后每一 ...

  6. 使用php实现权限管理模块

    在说权限管理模块前,应该先知道权限管理模块要有哪些功能: 1.用户只能访问,指定的控制器,指定的方法 2.用户可以存在于多个用户组里 3.用户组可以选择,指定的控制器,指定的方法   4.后台可以添加 ...

  7. 用Unity3.0+MVC4搭建项目

    新年快乐!又是新的一年到来了,我好久没有在园子里面做笔记啦,由于工作上的事,还好年前把该做的都完善了,于是就写了辞职信.由于家庭原因,不得不离职,在春节期间呢,我放松了几天,去这里去那里的,朋友们喜欢 ...

  8. Android网络请求心路历程

    HTTP请求&响应 既然说从入门级开始就说说Http请求包的结构.一次请求就是向目标服务器发送一串文本.什么样的文本?有下面结构的文本.HTTP请求包结构 例子: 1 2 3 4 5 6 7 ...

  9. Form.KeyPreview 属性

    Form.KeyPreview 属性 今天再做KeyDown 和 KeyUp 事件时,就是忘了设置,窗体的KeyPreview 属性,所以KeyDown 和 KeyUp 事件没有反应(这里说明一下,本 ...

  10. Sublime Text修改显示图标

    选择喜欢的图片 首先你需要选择一个中意的图片做为新的图标,格式可以是png,jpg,gif的 转为ico格式 我们需要ico格式的图片,所以需要将上述的图片转换一下格式.同样,转ico格式的软件很多, ...