首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js怎么动态加载js文件(JavaScript性能优化篇)转

下面介绍一种JS代码优化的一个小技巧,通过动态加载引入js外部文件来提高网页加载速度 【基本优化】 将所有需要的标签都放在之前,确保脚本执行之前完成页面渲染而不会造成页面堵塞问题...【合并JS代码,尽可能少的使用script标签】 最常见的方式就是带代码写入一个js文件中,让页面只使用一次标签来引入 ? 3....【无堵塞加载JS】 通过给script标签增加 defer属性或者是 async 属性来实现 注解: async...该原理实现的也有很多不错的js类库可以使用,如LazyLoad.js,支持数组的形式引入,打开浏览器在network中可看到js是同步加载的 ? ? 7....【XHR加载】 使用ajax方式加载 代码: var xhr = new XMLHttpRequest; xhr.open('get','file.js',true); xhr.onreadystatechange

19.6K12

JavaScript、js文件Node.js、静态文件

一、JavaScript 1、JavaScript认知 JavaScript(简称“JS”) 是一种解释型的脚本语言。广泛用于Web应用开发,对页面事件做出响应。...通常JavaScript脚本是通过嵌入在HTML页面中来实现自身的功能的,也可以写成单独的js文件。 JavaScript与Java名称上的近似,但是两种完全不同的语言。...文件 js文件是指包含JavaScript代码,以“.js”为扩展名的文本文档,用于在网页中执行JavaScript指令;可以说JS文件是网页JavaScript客户端脚本文件。...三、Node.js node.jsNode是一个让JavaScript运行在服务端的开发平台。...四、静态文件 定义:不是由服务器生成的文件就是静态文件 包含:web项目中的图片、css、js、文本文件txt、脚本、等静态资源,不带jsp、asp、php页面的HTML页面 特点: 1 通常存放在

6.3K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Node.js中模块加载机制

    7、Node.js中模块加载机制 (1)模块查找规则-当模块拥有路径但没有后缀时 image.png require方法根据模块路径查找模块,如果是完整路径,直接引入模块。...如果模块后缀省略,先找同名JS文件再找同名JS文件夹 如果找到了同名文件夹,找文件夹中的index.js 如果文件夹中没有index.js就会去当前文件夹中的package.json文件中查找main选项中的入口文件...如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到 (2)模块查找规则-当模块没有路径且没有后缀时 Node.js会假设它是系统模块 Node.js会去node_modules文件夹中...首先看是否有该名字的JS文件 再看是否有该名字的文件夹 如果是文件夹看里面是否有index.js 如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件 否则找不到报错...image.png Node网站服务器 能够提供网站访问服务的机器就是网站服务器,它能够接收客户端的请求,能够对请求做出响应。

    1.8K20

    Node.js】模块的加载机制

    内置模块的加载机制 内置模块是由Node.js官方提供的模块,内置模块的加载优先级最高。 意思是说  如果自定义模块,与内置模块同名,则优先会加载内置模块。        ...同时,在使用require()导入自定义模块时,如果省略了文件的扩展名,则Node 执行文件时会按顺序分别尝试加载以下的文件类领。.../开头,则Node.js会从当前父级模块开始查找子级node_modules文件夹,然后从里面查找导入的模块名称。...例如  在C:\Users\itheima\project\foo.js 文件里调用了require(‘tools’),则Node.js会按一下顺序查找。  ...package.json的文件,并寻找main属性,作为require()加载的入口 如果没有package.json文件,或者main属性不存在,文件不存在的话,则会加载目录下的index.js文件

    1.2K20

    Js文件异步加载

    Js文件异步加载 浏览器中渲染引擎与Js脚本引擎是互斥的,在浏览器开始渲染页面时,如果遇到标签,会停止渲染当前页面,也就是说在脚本加载与执行的过程中会阻塞页面的渲染,在网速较差的环境下可能会出现浏览器页面假死的情况...,这也就是尽量将文件放置于后的原因,Js文件异步加载就是使浏览器加载外部Js脚本文件时不阻塞渲染线程,这称为非阻塞模式加载,当然加载完成之后解析执行Js脚本时必须与渲染引擎互斥...,解析执行Js脚本的时机取决于异步加载Js的方式。...script type="text/javascript" defer="defer" src="https://cdn.jsdelivr.net/npm/jquery@3/dist/jquery.min.js..." > Script DOM Element Script DOM Element的方式即动态插入一个标签来加载外部Js脚本文件,将其作为onload事件的回调函数,即在页面加载完成后再执行

    10.4K20

    Node.js中模块加载机制

    /find.js') ; require(' ./find') ; require方法根据模块路径查找模块,如果是完整路径。直接引入模块。...如果模块后缀省略,先找同名JS文件再找同名JS文件夹 如果找到了同名文件夹,找文件夹中的index.js 如果文件夹中没有index.js就会去当前文件夹中的package.json文件中查找...main选项中的入口文件 如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到 2.模块查找规则-当模块没有路径且没有后缀时 require(' find') ; Node.js...会假设它是 系统模块 Node.js会去node_ modules文件夹中 首先看是否有该名字的JS文件 再看是否有该名字的文件夹 如果是文件夹看里面是否有indexjs...如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件 否则找不到报错

    1.3K30

    Node.js中模块加载机制

    /find.js') ; require(' ./find') ; require方法根据模块路径查找模块,如果是完整路径。直接引入模块。...如果模块后缀省略,先找同名JS文件再找同名JS文件夹 如果找到了同名文件夹,找文件夹中的index.js 如果文件夹中没有index.js就会去当前文件夹中的package.json文件中查找...main选项中的入口文件 如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到 2....模块查找规则-当模块没有路径且没有后缀时 require(' find') ; Node.js会假设它是 系统模块 Node.js会去node_ modules文件夹中 首先看是否有该名字的...JS文件 再看是否有该名字的文件夹 如果是文件夹看里面是否有indexjs 如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件 否则找不到报错

    1.8K20

    Node.JS】读取文件内容

    目录 fs文件系统模块 fs.readFile() 成功时, 失败时, ---- fs文件系统模块 fs模块是Node.js官方提供的,用来操作文件的模块,它提供了一系列的方法和属性,用来满足用户对文件的操作需求..., 例如:fs.readFile()方法,用来读取指定文件中的内容。...如果想要在js代码中,使用fs模块来操作文件,则需要使用如下的方式先导入它。...参数二:options是可选参数,表示用什么编码格式来读取文件,默认utf-8。...参数三:callback是必选参数,文件读取完成后,通过回调函数拿到读取的结果,回调函数有两个值, 成功时, 第一个值是没有读取产生的值为null,第二个值为读取成功拿到的值。

    11.6K20

    Node.js获取文件文件类型

    在使用Node进行文件处理时我们经常会需要不同类型的文件进行不同的处理,并且对客户端进行对应的请求头返回,这里推荐两个个插件进行文件类型的快速获取文件类型。...1.mime 可以获取文件的mime-type用于请求头返回 res.writeHead(200, { 'Content-type': mime.getType(`public/...a.webp`)// image/webp }); res.write(chunk); 只需要引入插件,然后使用对应的函数传入文件路径就可以获取mime-type了 2.file-type...功能齐全,可以通过文件或者Buffer流来进行文件类型,并且不仅可以获取mime-type也可以获取文件后缀类型 import {fileTypeFromFile} from 'file-type';...console.log(await fileTypeFromFile('Unicorn.png')); //=> {ext: 'png', mime: 'image/png'} 并且官网上给出了使用方法,也是通过传递文件路径或者

    7.8K10

    Node.js+Mock.js+Vue.js实现接口和上拉加载数据

    Express官网 、 Mock.js官网 Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具。...Mock.js 用来生成随机数据,拦截 Ajax 请求 1、创建项目 新建一个名为interface的文件夹 创建 package.json文件,在命令行窗口中输入> cnpm init ,接着默认回车就行...最后在interface文件夹里面新建一个名为app的js文件。...项目结构 interface ├── node_modules ├── app.js ├── package.json 2、代码部分 app.js 代码 var express = require("express...用到了vue.js,如果不会的可以先去 Vue.js 的官网教程中去看看它的语法 还用了vue-lazyload.js 实现图片懒加载,直接引用拿过来用就行了,很方便。

    2.6K30

    Node.js怎么找到模块的?

    大家好,我是前端西瓜哥,今天我们来看看 Node.js 模块查找的原理。 模块种类 模块有三种来源。 核心模块:Node.js 内置的包。比如 http、fs、path; 自定义模块:NPM 包。...文件模块 包通常是一个文件夹,里面会有 package.json 文件Node.js 会提取其中 main 字段对应的文件作为模块文件。...如果没有,就依次查找该目录下的 index.js、index.json、index.node 文件。 需要查找的目录可以通过 module.paths 变量得到。...后缀按顺序添加为:.js 、.json、.node,找到就立即返回。若一个文件没有后缀但被匹配到了,它会被当作 js 文件。 上面没说缓存的情况,其实我们会对模块做缓存,下面详细说明一下。...模块缓存 每当加载一个模块后,这个模块就会被缓存起来。 你可以在随意一个文件中输入得到缓存的内容,是一个哈希表,key 为模块的绝对路径,确保缓存命中,value 则是模块对象。

    2.1K10
    领券