来自《javascript高级程序设计 第三版:作者Nicholas C. Zakas》的学习笔记(二)

  使用html标签<script>可以把js嵌入到html页面中,让脚本与标记混合一起;也可以包含外部的js文件。如:

  1. 脚本和标记混合:

    <script type="text/javascript">
    function sayHi(){
    alert("Hi");
    }
    </script>

    在使用<script>嵌入代码时,记住不要在代码中的任何地方出现'<script>'字符串。例如,

    <script text="text/javascript">
    function sayScript(){
    alert("</script>");
    }
    </script>

    浏览器在加载上述代码时将会报错,因为当浏览器遇到字符串</script>时,就会认为那是结束的</script>标签。解决办法如下:

    <script text="text/javascript">
    function sayScript(){
    alert("<\/script>");
    }
    </script>
  2. 外部js文件的链接,例如:
    <script type="text/javascript" src="example.js"></script>

    需要注意的是:带有src属性的<script>元素不应该在其<script></script>标签之间有额外js代码。只会下载并执行外部脚本文件,嵌入的代码会被忽略。src属性还可以包含来自外部域的js文件,如:

    <script type="text/javascript" src="http://www.somewhere.com/afile.js"></script>

    不过随意加载外部域js文件存在潜在危险,需要引起警惕。 

  而我们需要注意的地方有:

  • 在包含外部js文件时,必须将src属性设置为指向相应文件的URL。而这个文件可以与包含它的页面位于同一个服务器上,也可以是其他任何域中的文件(如:)
  • 所有<script>元素都会按照它们在页面中出现的先后顺序依次被解析。在不使用defer和async属性的情况下,只有在解析完前面<script>元素中的代码之后,才会开始解析后面<script>元素中的代码(后面将会补充defer和async的知识,就如你此时脑瓜子里猜测的那样,defer和async就是能够控制解析顺序的。不过还有细节方面的知识,如果您此时已经迫不及待想知道,可以先翻阅到该文章的相应段落,抢先阅读)。
  • 由于浏览器会先解析完不使用defer属性的<script>元素中的代码,然后再解析后面的内容,所以一般应该把<script>元素放在页面最后,即主要内容后面,</body>标签前面。从而可以避免出现js文件下载过慢出现页面无法渲染的情况。
  • 使用defer属性可以让脚本在文档完全呈现之后执行。延迟脚本总是按照指定它们的顺序执行。
  • 使用async属性可以表示当前脚本不必等待其他脚本,也不必阻塞文档呈现。不能保证异步脚本按照它们在页面中出现的顺序执行。
  • 使用<noscript>元素可以指定不支持脚本的浏览器中显示的替代内容。但在启动了脚本的情况下,浏览器不会显示<noscript>元素中的任何内容。

  

  defer和async介绍:

  标签<script>的defer属性的定义(defer只适用于外部脚本),是脚本会被延迟到整个页面都解析完毕后再运行。这个属性的用途表明脚本在执行时不会影响页面的构成。如:

<script type="text/javascript" defer="defer" src="example1.js"></script>
<script type="text/javascript" defer="defer" src="example2.js"></script>

  需要注意的是,现实生活中,example1.js和example2.js虽然延迟了,但是彼此作为都是延迟脚本并不是example1.js一定会先于example2.js执行,也不一定会在DOMContentLoaded事件触发前执行,因此最好只包含一个延迟脚本。

  同样属性async也只适用于外部脚本,并告诉浏览器立即下载文件,但不妨碍页面中的其它操作,比如下载其它资源或是等待加载其它脚本。标记为async的脚本并不保证按照指定它们的先后顺序执行。所以。确保两者之间互不依赖非常重要。指定async属性的目的是不让页面等待两个脚本执行和下载,从而异步加载页面其它内容。建议异步脚本不要在加载期间修改DOM。

  补充:如何防止浏览器缓存外部js文件,很多时候用于动态验证码等需要多次加载文件的时候。

  原理其实就是通过在固定地址后面,加上一个不同值的日期数值,以达到地址不重复的目的,让浏览器每次都实时加载,不从缓存中读取文件。

<script type="text/javascript">
//防止js文件缓存下来,以后更新时不再需要用户重新删除IE文件等操作。
var now=new Date();
var number = now.getYear().toString()+now.getMonth().toString()+now.getDate().toString()+now.getHours().toString()+now.getMinutes().toString()+now.getSeconds().toString();
document.write('<scr'+'ipt language="javascript" type="text/javascript" src="jb51net.js?"+number+""></scr'+'ipt>');
</script>

  学习笔记。

js和HTML结合(补充知识:如何防止文件缓存的js代码)的更多相关文章

  1. Nodejs学习笔记(六)--- Node.js + Express 构建网站预备知识

    目录 前言 新建express项目并自定义路由规则 如何提取页面中的公共部分? 如何提交表单并接收参数? GET 方式 POST 方式 如何字符串加密? 如何使用session? 如何使用cookie ...

  2. Nodejs学习笔记(六)—Node.js + Express 构建网站预备知识

    前言 前面经过五篇Node.js的学习,基本可以开始动手构建一个网站应用了,先用这一篇了解一些构建网站的知识! 主要是些基础的东西... 如何去创建路由规则.如何去提交表单并接收表单项的值.如何去给密 ...

  3. modeJS 深了解(1): Node.js + Express 构建网站预备知识

    转载:http://www.cnblogs.com/zhongweiv/p/nodejs_express_webapp1.html 目录 前言 新建express项目并自定义路由规则 如何提取页面中的 ...

  4. BBS项目补充知识(后台文章展示功能)

    BBS项目补充知识 1. 开放 media 文件路径 # 以用户注册页面为例 用户头像文件我们默认时保存在 根路径下的static下的img文件夹 但也可以单独放置在指定路径下 # 根路径下创建 me ...

  5. 《Ext JS模板与组件基本知识框架图----模板》

    最近在整理Ext JS的模板和组件,在参考<Ext JS权威指南>,<Ext JS Web应用程序开发指南>,<Ext JS API>等相关书籍后才写下这篇< ...

  6. 031医疗项目-模块三:药品供应商目录模块——供货商药品目录查询功能----------sql补充知识

    这个补充知识有一个点很有必要,视屏上的老师提出一点: 内链接关联查询: 如果表A和表B有一个外键关联 ,可以通过外键进行内链接查询 select dictinfo.*, dicttype.typena ...

  7. JS模块化工具require.js教程(二):基本知识

    前一篇:JS模块化工具我们以非常简单的方式引入了requirejs,这一篇将讲述一下requirejs中的一些基本知识,包括API使用方式等 基本API require会定义三个变量:define,r ...

  8. 面向对象 - 1.面向过程/2.面向对象/3.如何使用类/4.__init__方法/5.属性查找/6.补充知识/7.可扩展性高

    编程范式(流派): 面向对象编程,面向过程编程 各有用处!! 编程:语法+数据结构(list dict)+算法(逻辑)-----------------------------------1.面向过程 ...

  9. freeMarker(五)——模板开发指南补充知识

    学习笔记,选自freeMarker中文文档,译自 Email: ddekany at users.sourceforge.net 模板开发指南补充知识 1. 自定义指令 自定义指令可以使用 macro ...

随机推荐

  1. Unity出现 error building player exception android (invocation failed)

    今天在编译Android的时候出现这个错误 error building player exception android (invocation failed) 百度谷歌之后,看到xuanyuson ...

  2. Aliyun OSS SDK 异步分块上传导致应用异常退出

    问题描述: 使用Aliyun OSS SDK的BeginUploadPart/EndUploadPart执行异步分块上传操作,程序出现错误并异常退出! 原因分析: Using .NET Framewo ...

  3. Cocos2d-x中背景音乐播放暂停与继续

    背景音乐播放暂停与继续似乎我们很少使用,事实上也正是如此,背景音乐播放暂停与继续实例代码如下: SimpleAudioEngine::getInstance()->pauseBackground ...

  4. XML解析的例子

    ////  main.m//  homewoek////  Created by hehe on 15/9/9.//  Copyright (c) 2015年 wang.hehe. All right ...

  5. 相似度到大数据查找之Mysql 文章匹配的一些思路与提高查询速度

    文章相关度匹配的一些思路---"压缩"预料库,即提取用特征词或词频,量化后以“列向量”形式保存到数据库:按前N组词拼为向量组供查询使用,即组合为1到N字的组合,量化后以“行向量”形 ...

  6. 【转】 SqlServer性能检测和优化工具使用详细

    http://blog.csdn.net/dcx903170332/article/details/45917387

  7. Json文件/网址解析

    // // main.m // OC8-Json文件解析 // // Created by qianfeng on 15/6/23. // Copyright (c) 2015年 qianfeng. ...

  8. spring junit参数

    备忘,以后有时间再写点东西吧.其实自己就没有开始写过. blog地址:http://www.cnblogs.com/shizhongtao/p/3342174.html //spring 配置的路径, ...

  9. Java中的数组排序

    Java中的数组排序,一般是利用Arrays.sort(),这个方法是经过优化的快速排序.在Arrays种有多中形式的重载,在这里就不一一列举了. 数组排序的种类: 1.非降序排序, 非升序排序(就排 ...

  10. bzoj 3626 LCA

    这一道题咋一看只觉得是离线,可以求出所有的f(1,i,z), 答案就等于f(1,r,z)-f(1,l-1,z).但是没有具体的做法,但是求LCA的深度和有一个非常巧妙的做法,每加一个点,就把这个点到根 ...