2019-12-10:第二章:在HTML中使用javascript && 部分第三章:js基础

一.<script>元素

首先需要确立一个观念:即js是浏览器的脚本,浏览器并不直接与javacript进行交互,浏览器也不认识js代码。其交互逻辑是:当DOM树生成后,其中有一类节点叫做<script>***</script>,当浏览器中的HTML解析器读取到这类节点后,则会自动调用js引擎解析并执行。翻译并执行js的过程是无法异步的(或者说无法真正意义上的异步,async和defer都只是声明某个script延迟加载而已),因此,在加载javacript资源时,HTML解释器有可能发生阻塞。(加载script资源时,浏览器无法同时做其他事)

浏览器的工作逻辑

根据上图的描述,我们可以知道:在加载script元素时,DOM树是未必完成创建了的。因此,在工程中,一类常见的js报错就是无法获取到DOM对象,这大多数是由于script元素在HTML中的位置所引起的。因此,在真正的开发工程中,为了避免以上两处黑体所描述的问题发生,我们提倡将script标签放在页面底部。这样做的好处是可以保证HTML解释器读取到script标签时,DOM树的构建一定已经完成

  1.<script>元素

    简单讲,script标签就是在DOM树中存储javacript代码的地方。他具有六个基本属性:

        ① async:非必填;代表异步加载script(异步加载的意思在是不阻塞DOM树构建的前提下加载script元素),此属性只对外部引用有效。

        ② charset:非必填;指定字符集,定义外部js中所使用的字符集类目,例如UTF-8。

        ③ defer:非必填;与async类似,区别是defer代表的是要求浏览器将其他DOM部分完全解析后,再来加载本脚本。同样只对外部引用有效。

        ④ language:废弃。

        ⑤ src:外部js的引用位置。

        ⑥ type:现代浏览器中非必填;声明该script标签内内容的语言类型,不是很重要,默认值为text/javascript。

    script标签有两种使用方式:内嵌或外部引用。外部引用必须通过src取得文件位置,可以是HTML链接(外部域),也可以是文件路径。当浏览器开始解析script标签时,其将自上向下依次解析(这与部分强类型语言不同,例如java,cpp会优先提取代码中的变量,将其升格到作用区域的顶端,再解析语句),在script整个标签的解析完成前,浏览器不会对外释放任何script修改或添加的内容

    另外,当使用外部引用作为script标签时,注意浏览器不会通过src中的后缀名识别js文件,因此,我们便可以通过server端的JSP,PHP动态生成js以供浏览器使用。

小知识

    另外,当一个HTML文档中存在若干个<script>标签时,如果大家都没有async或defer属性修饰,那么浏览器会从上向下依次加载翻译script标签,换句话说,浏览器是个非常守规矩的学生:他只有把第一道题做完了(加载好一个script标签中的内容),浏览器才会来看第二道题(才来加载第二个script标签)。除非这道题右上角标注了:"这道是压轴题",或者"不做这道题也不影响你做其他题目"(用defer或async修饰)

    1.1 script标签的位置

    推荐在HTML文档中将script标签放置与<body>标签的底部,原因是浏览器只有加载到body标签时,才会向页面中填充内容,head标签则不会,如果将script标签置于body标签的底部,则会无形中让人们以为页面加载的速度变快了(实际没有,因为大部分script标签是在页面完全填充之后才开始翻译的);

    1.2 延迟加载

    详细解释一下script标签中defer属性的含义:立刻下载,但延迟翻译(先把理综卷子拿到手,但是其他科目都做完了再做理综)。其执行时间为先于DOMContentLoaded事件发生。同时,多个延迟脚本遵从FIFO的原则,先进先出。

    1.3 异步脚本

    async和defer的含义相近,但却并不完全相同,区别有以下几点:① 是async不保证多个延迟脚本FIFO,其加载过程是完全随机的。有可能先被执行的<script async = 'async'/>反而后被加载。② 是async一定会在页面的loaded事件前执行但有可能在DOMContentLoaded事件前后发生。

    剩余的1.4 XHTML中的使用以及1.5不推荐写法在工程中使用较少,不多做赘述。

  2.嵌入代码与外部文件

一句话解释,建议使用外部文件而不是嵌入代码,理由有三:可维护性;可缓存(多个页面使用相同js,提升加载速度);适应XHTML;

  3.文档模式与标准模式

时代的余晖,不多废话了。

时代的余晖

  4.nosscript标签

一句话解释,当一个浏览器不支持script时(21世纪了,还有浏览器不支持js嘛??),如何避免报错:使用<nosscript>。不支持script的浏览器会自动跳过此标签继续DOM树的加载。


第三章  基本概念

一&&二&&三.基础定义与概念

这部分因为比较简单,且语言与语言之间形态较为相近,我就大致总结一下不多废话了,主要有一下几点:

    ①js中区分大小写;

    ②js标识符必须以字母,下划线,美元符号($)开头.

    ③js建议使用驼峰命名(无论函数还是标识符,都首字母小写,剩下每个有意义的单词首字母大写,例如:hunterMonsterIceborn)

    ④js的注释为/*  **  */ 和 //两种,分别代表块注释和行注释。

    ⑤严格模式

    ⑥js结尾不需要分号(当然,你也可以写)

    ⑦关键字与保留字:见下图(ES5标准)


ES第六版还新增加了async/await等,可参见https://es6.ruanyifeng.com/

    ⑧变量。js中的变量时松散模式,又称弱类型。js的变量仅仅只是一个占位符,他指明在系统内存中的某段地址,针对这段地址的值的分配没有任何要求。你可以将一个原本为string类型的变量随时修改为number,date,or any u want,当然,除非他是被const定义过的常量。

    另外,在全局用var定义过的变量是全局变量,而在域内用var定义的变量是局部变量,在函数执行结束后,该变量将被js的垃圾回收机制收回销毁,同时释放内存地址。(这个含糊的写法已经在ES6中通过引入let完成了修正。)。但是同样的,你也可以通过在函数中省略var来直接定义变量,此时即便在函数内定义的变量仍然为全局变量,即便函数运行完成被销毁,该变量仍然可以在全局作用。

不使用var在函数中定义全局变量

四.数据结构

js的数据结构非常简单,在ES3及以下定义中,js有且仅有Undefine,Null,Number,String,Boolean,以及复杂类型Object六种结构。其中Object的本质即是无序的键值对,(类似Python中的dict字典)类似Date,DOM,HTML都是通过这种结构的复杂组成得到的。对了,忘记说了,Array,Function在js中也都是Object。另外,js在ES5和ES6中又添加了一种新的数据结构:Set(当然了,本质也是Object)

1.检测手段typeof

    typeof()是js中用来检测字符数据类型的工具函数。

        undefine:该变量未定义,但是需要注意,定义了但没有赋值的变量=undefine,未定义的变量则会报错(未分配地址)

如同上文所述,未定义的变量可不是undefine

        boolean/string/number:该变量为布尔型,字符串,数字型


        object:该变量为类或Null,特殊值null本质上是一个空的类型引用

当且仅当一个object为null,才会判断为false哦

        function:该变量为函数(函数也是类,暂且不表)

2.几种变量的特殊点

    ① null类型本质上是一个空对象指针,因此,如果将来想要将一个变量赋值为Object,那么风格建议我们将这个变量设为null;另外,null与undefine的值判断也是值得记录的点:

一句话,null==undefine;unll!===undefine

   ② boolean类型比较值得记录的是当发生强制类型转换时的转换法则,如下图所示:

boolean()转换法则

    ③ Number类型可以表示整数和浮点数,其中整数又可以以八进制,十进制,十六进制来表示。但同时也要注意,八进制的写法在严格模式下是无效的。number类型支持用eN来代表科学计数法。有关浮点数,有以下几点可以学习:

                <.1的写法是合法的,代表0.1>

                <1.的写法是合法的,代表1(整型)>

                <10.0的写法是合法的,代表10(整型)>

                <浮点数的精度相当堪忧,能不用还是不要用>

        ④ NaN代表本来要返回一个数字类型,但是因为处理出错而没有正确返回的情况,NaN是一个非常特殊的类型,在js中,任何数字除以0都会返回NaN,除此之外,任何涉及到NaN的计算,都只会返回NaN;而且NaN不与任何值相等,包括他自己。

ES6中,使用Infinity代替了NaN

        基于上述的特点,js开发了isNaN()函数,该函数的功能是判断任意一个变量能否转换为NaN,如果可以,返回True,否则返回false,我们可以利用这种特性来进行变量数据类型的确定。

isNaN()的例子
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352