图片懒加载和预加载

JavaScript027

图片懒加载和预加载,第1张

懒加载也叫延迟加载,指的是在长网页中延迟加载图像,是一种很好优化网页性能的方式 。用户滚动到它们之前,可视区域外的图像不会加载。这与图像预加载相反,在长网页上使用延迟加载将使网页加载更快。在某些情况下,它还可以帮助减少服务器负载。常适用图片很多,页面很长的电商网站场景中。

首先将页面上的图片的 src 属性设为空字符串,而图片的真实路径则设置在data-original属性中, 当页面滚动的时候需要去监听scroll事件,在scroll事件的回调中,判断我们的懒加载的图片是否进入可视区域,如果图片在可视区内将图片的 src 属性设置为data-original 的值,这样就可以实现延迟加载。

资源预加载是另一个性能优化技术,我们可以使用该技术来预先告知浏览器某些资源可能在将来会被使用到。 预加载简单来说就是将所有所需的资源提前请求加载到本地,这样后面在需要用到时就直接从缓存取资源

在网页全部加载之前,对一些主要内容进行加载,以提供给用户更好的体验,减少等待的时间。否则,如果一个页面的内容过于庞大,没有使用预加载技术的页面就会长时间的展现为一片空白,直到所有内容加载完毕。

<img src="http://pic26.nipic.com/20121213/6168183 0044449030002.jpg" style="display:none"/>

<script src="./myPreload.js"></script>

PreloadJS提供了一种预加载内容的一致方式,以便在HTML应用程序中使用。预加载可以使用HTML标签以及XHR来完成。默认情况下,PreloadJS会尝试使用XHR加载内容,因为它提供了对进度和完成事件的更好支持,但是由于跨域问题,使用基于标记的加载可能更好。

两者都是提高页面性能有效的办法, 两者主要区别是一个是提前加载,一个是迟缓甚至不加载。懒加载对服务器前端有一定的缓解压力作用,预加载则会增加服务器前端压力

转: https://juejin.cn/post/6844903614138286094

1、尝试在远端网页直接require('electron')报以下错误

Electron的一个主要特性就是能在渲染进程中运行Node.js,html或者vue项目不能直接require('electron')

想要壳与网页分离,并且达成交互,需要双向定义事件,而 electron只需在壳中 引 用

2、创建浏览器窗口

3、预加载文件方式:

这里预加载文件可以通过 new BrowserWindow中的preload,也可以

加载远程URL

3、electron与远端网页交互

4、sandbox  沙盒选项

5、 sandbox 模式下,文件之间相互调用 (如:preload.js中访问config.js对象)不能直接require,调用方式如下:

方式1:

方式2:

一、seajs.config配置说明:

1.base说明:

base是字符串类型,表示基础或叫做根路径(最好绝对地址)

备注:

(1)base如果不写的话是根据你引用sea.js的地址目录

(2)base如果写了’.’或者 ‘/’或者’ ’这些,会默认从服务根目录开始

(3)base如果写了’js/’之类的相对路径,会默认根据你引用sea.js的地址目录

例如:

seajs.config({

base: 'http://example.com/path/to/base/'

})

2.alias说明

例如:

seajs.config({

base: 'http://example.com/path/to/base/',

// 别名配置

alias: {

'es5-safe': 'gallery/es5-safe/0.9.3/es5-safe',

'jquery': 'jquery/jquery/1.10.1/jquery'

}

})

引入的时候:加载模块(seajs.use("es5-safe"))  引入模块 :(require("jquery"))

3.paths说明:

当目录比较深,或需要跨目录调用模块时,可以使用paths来简化书写。

例如:

seajs.config({

base:'http://example.com/path/to/base/',

//表示路径配置

paths:{

'cwd':'static/common/js'

},

alias: {

'es5-safe': 'gallery/es5-safe/0.9.3/es5-safe',

'jquery': 'jquery/jquery/1.10.1/jquery',

'jquery':'cwd/common/jquery-1.11.3'//alias中使用 static/common/js/common/jquery-1.11.3

}

})

seajs.use('cwd/project/AA')//static/common/js/project/AA

var index = require(cwd/index)//  static/common/js/index.js

4.map说明:

map是Array类型,表示配置可对模块路径进行映射修改,可用于路径转换、在线调试等。

例如:

seajs.config({

map: [

//[ '.js' ,  '-debug.js' ]

['.js' , '.js?_t='+(new Date).getTime()]

]

})

define(function(require, exports, module) {

var a = require('./a')

//=>加载的是 path/to/a-debug.js

})

5.preload说明:(备注该属性在V2.3版本时候去除了)

preload是Array或String类型,表示预加载项,可以在普通模块加载前,提前加载并初始化好指定模块。

备注:preload中的空字符串会被忽略掉。使用时需要等到 use 才加载

例如:

seajs.config({

preload: ["jquery"]

})

6.debugBoolean 调试使用

值为 true 时,加载器不会删除动态插入的 script 标签。插件也可以根据 debug 配置,来决策 log 等信息的输出。

seajs.config({

debug:true

})

7.vars变量配置

有些场景下,模块路径在运行时才能确定,这时可以使用vars变量来配置。

seajs.config({

vars: {

'locale': 'zh-cn'

}

})

define(function(require, exports, module) {

var lang = require('./i18n/{locale}.js')

//=>加载的是 path/to/i18n/zh-cn.js

})

vars配置的是模块标识中的变量值,在模块标识中用{key}来表示变量。

二、 define

1.所有模块都通过 define 来定义

define(function(require, exports, module) {

(1). // 通过require.async引入依赖(引入模块)

require.async是异步加载的在引入后,的回调函数中才能使用,函数返回值就是require对象

require.async("jquery",fun) 异步加载模块  jquery(别名)  fun回调函数(可选参数)

require.async(['lib/common/common.js','lib/common/index.js'],function(){

Echo.init({

offset: 150,  //离可视区域多少像素的图片可以被加载

throttle: 10  //图片延迟多少毫秒加载

})

})  //调用多个模块    fun回调函数可选()

(2).require引入依赖(引入模块)

Require引入就可以使用

var Spinning = require('lib/common/common.js')  基础地址/lib/common/common.js

Spinning.tostring()      调用Spinning里面的tostring方法

require直接引入整个文件

require.async(["swiper"], function() {

require('module/Mycenter/mycenter')

})

2.对外暴露接口

// 通过exports对外提供接口

exports.tonumber = function(){ var  a = 0}

// 或者通过module.exports提供整个接口  (推荐使用)

module.exports.tonumber = function(){ var  a = 0}

})

三 、use()

seajs.use 用来在页面中加载模块。通过 use 方法,可以在页面中加载任意模块。use 的模块路径相对于当前页面

语法:seajs.use(id, callback?)

// 加载模块 main,并在加载完成时,执行指定回调

seajs.use(‘./main’)加载模块

seajs.use(‘./main’, function(main) {

main.init()

})

use 方法还可以一次加载多个模块:

// 并发加载模块 a 和模块 b,并在都加载完成时,执行指定回调

seajs.use(['./a', './b'], function(a, b) {        加载多个模块  fun回调函数(可选参数)

a.init()

b.init()

})

四、注意

引入 sea.js 时,可以把 sea.js 与其他文件打包在一起,可提前合并好,或利用 combo 服务动态合并。无论哪一种方式,为了让 sea.js内部能快速获取到自身路径,推荐手动加上 id 属性: