来自《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. Asp_CRUD

    Asp_增删改查.逻辑流程 启动服务器. 地址为127.0.0.1 端口为随机分配 2607 然后在浏览器中输入http://localhost:2670/CRUD_main.ashx 浏览器像服务器 ...

  2. WCF Membership and Role Provider

    本文介绍的是如何使用Membership 和 Role Provider 来控制 WCF 调用方法的权限. 比如我们有一个WCF Method 叫 GetData(int num),然后我们只允许Ro ...

  3. Android的ListView分页功能

    一.功能分析----ListView“加载更多”,功能如下图所示: 这个效果是当你上拉拖动页面时(注意有区别于下拉刷新),页面提示正在加载,2秒后显示留言更多内容:具体功能知道那我就来讲解下如何实现这 ...

  4. Android之屏幕测试

    MainActivity: package com.example.touchscreentest; import android.os.Bundle; import android.R.layout ...

  5. Insert data from excel to database

    USE ESPA Truncate table dbo.Interface_Customer --Delete the table data but retain the structure exec ...

  6. AngularJS 学习随笔(一)

    AngularJS 初始化加载流程: 1:浏览器载入HTML,然后把它解析成DOM 2:浏览器载入Angular.JS 脚本 3:AngularJS 等到DOMContentLoaded时间触发 4: ...

  7. 三星智能手机如何运用Smart Switch?

    1.Smart Switch是指? 使用前注意事项: 将两部智能手机的距离保持在50cm以内 两部智能手机都下载相同的最新版本Smart Switch 确认可支持的机器参考应用程序说明 不受干扰的安静 ...

  8. ios开发入门篇(一):创建工程

    突然心血来潮,想写点技术方面的东西,做了ios也有好几年了,就简单的写个ios开发的技术博客,希望有人能用得到. 今天就先从创建一个Hellow World工程开始 一:首先打开xcode然后单击Cr ...

  9. sqlplus 可以登录 plsql 不能登录

    最开始我以为是system用户被锁定了,但是解锁后仍然不可以登录.大神指导之后可以了,说是缺少监听器,解决过程如下: 1.将“tnsnames.ora”和“listener.ora”两个文件里的“lo ...

  10. myeclipse与数据库进行连接(无需写代码进行验证)

    首先对SqlServer配置管理器进行设置. 1.打开SqlServer配置管理器 2.进入SQL配置管理器后,选中左侧“SQL Server网络配置”>>再选中“MSSQLSERVER的 ...