JavaScript 学习笔记之一jQuery写法图片等比缩放以及预加载
以前对于JavaScript总是在用到的时候在页面上写几个函数,基本没考虑到函数的封装与重用,最近有个项目可能对于这方面要求有点高,所以就研究了下类似jQuery的封装。
这里就图片等比缩放以及预加载的效果来尝试下,写写类似的JavaScript代码。
图片等比缩放以及预加载的效果如下(预加载效果有时候会不是很明显):
JS主要代码如下:
(function() {
var yQuery = (function() {
var yQuery = function() {
return yQuery.fn.init();
};
yQuery.fn = yQuery.prototype = {
init: function() {
return this;
},
//图片等比缩放以及预加载方法申明 但是感觉这样写(return new imgResizeBox(e))很别扭 请高手赐教
imgResize: function(e) {
return new imgResizeBox(e);
}
};
//image图片处理
var imgResizeBox = function(e) {
//image参数
setting = {
imgId: "", //图片的容器的ID 比如.viewArea img
height: 0,
width: 0,
loading: "images/lightbox-ico-loading.gif"
};
$.extend(setting, e, setting); //参数替换
var images = $(setting.imgId); //获取所有图片
$(images).hide(); //隐藏
var loading = new Image(); //预加载图片
loading.className = "loading";
loading.src = setting.loading;
$(images).after(loading);
//预加载函数
var perLoading = function($this) {
var img = new Image();
img.src = $this.src;
if (img.complete) {
computeImg.call($this);
return;
};
img.onload = function() {
computeImg.call($this);
img.onload = function() { };
};
};
//图片缩放处理,以及图片显示函数
var computeImg = function() {
var m = this.height - setting.height;
var n = this.width - setting.width;
if (m > n)
this.height = this.height > setting.height ? setting.height : this.height;
else
this.width = this.width > setting.width ? setting.width : this.width;
$(this).next(".loading").remove();
$(this).show();
};
//循环调用预加载函数
return $(images).each(function() {
perLoading(this);
});
}
return yQuery;
})();
window.yQuery = window.$$ = yQuery();
})();
调用代码如下:
$(document).ready(function()
{
$$.imgResize({ imgId: ".viewArea img", height:160, width:270, loading: "http://www.jb51.net/images/2012/155618/2012062710243954.gif" });
});
最后附上简单的源码: jsDemo_jb51.rar

Vue中如何处理图片的缓存和预加载?在开发Vue项目时,我们经常需要处理图片的缓存和预加载,以提高网站性能和用户体验。本文将介绍一些Vue中处理图片缓存和预加载的方法,并给出相应的代码示例。一、图片缓存使用图片懒加载(LazyLoading)图片懒加载是一种延迟加载图片的技术,即在页面滚动到图片所在位置时才加载图片。这可以减少首次加载页面时对图片资源的请求

随着Web应用程序的日益复杂,前端开发人员需要在保证页面加载速度的前提下更好地提供功能和用户体验。这就涉及到Vue组件的懒加载和预加载,它们是优化Vue应用程序性能的重要手段。本文将深入介绍Vue组件的懒加载和预加载的实现方法。一、什么是懒加载懒加载就是当用户需要访问某个组件时才会把该组件的代码加载进来,而不是一开始就把所有组件的代码都加载进来,这样可以减少

UniApp实现图片处理与预加载的设计与开发技巧引言:在移动应用开发中,图片处理和预加载是常见的需求。UniApp作为一个跨平台的开发框架,提供了方便快捷的图片处理与预加载功能。本文将介绍UniApp中实现图片处理与预加载的设计和开发技巧,并给出相应的代码示例。一、图片处理的设计与开发缩放图片在UniApp中,要对图片进行缩放,可以使用<uni-ima

在网页开发中,图片预载是一种常见的技术,可以提升用户的体验感。当用户浏览网页时,图片可以提前下载并加载,减少图片加载时的等待时间。在Vue框架中,我们可以通过一些简单的方法来实现图片预载。本文将介绍Vue中的图片预载技术,包括预载的原理、实现的方法和使用注意事项。一、预载的原理首先,我们来了解一下图片预载的原理。传统的图片加载方式是等到图片全部下载完成才显示

Vue技术开发中如何处理图片资源的懒加载和预加载随着网页内容的丰富化,图片已经成为网页中必不可少的一部分。然而,大量的图片资源加载可能会导致网页加载速度变慢,影响用户的体验。为了解决这个问题,我们可以使用图片资源的懒加载和预加载技术来优化用户体验。一、懒加载技术懒加载是指网页中的图片在初次加载时只加载可视区域内的图片,当用户滚动页面到达图片所在区域时再加载图

高德地图是大家在出行时经常使用的一款导航软件,在其中有一个预加载沿途图片的功能,有些朋友对此还不是很了解,下面为大家介绍一下开启该功能的方法。在手机上打开高德地图应用程序后,转到右下角的“我的”选项,然后点击右上角的“六边形”设置图标以打开设置页面。2.来到设置页面后,其中有一个“足迹设置”,在它的上面点击进入。3.接下来在足迹设置页面里找到“预加载沿途照片”,在它的后面显示有一个开关按钮,在上面点击滑块把它设置为蓝色即可开启该功能,使用高德地图的过程中可以一键添加沿途照片。

随着互联网的快速发展,现代社会已经离不开各种各样的网站。然而,对于网站开发者和运营者来说,一个高性能的网站是至关重要的。一个快速响应、加载速度快的网站不仅可以提供更好的用户体验,还能提高搜索引擎优化的排名。本文将介绍五种关键技巧,帮助提升网站性能。首先,压缩网页内容是提升网站性能的重要一环。大多数网站都包含大量的前端资源,如HTML、CSS、JavaScri

PHP开发缓存的预热与预加载,需要具体代码示例随着互联网和移动应用的快速发展,用户对于网站和应用的响应速度要求也越来越高。为了提升用户体验,缓存一直被广泛应用于网站和应用开发中。而在PHP开发中,缓存的预热和预加载是提升性能的重要环节。本文将介绍PHP开发中缓存的预热与预加载的概念,并给出具体的代码示例。一、缓存的预热缓存的预热是指在系统启动或数据更新之前,


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

SublimeText3汉化版
中文版,非常好用

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

SublimeText3 Linux新版
SublimeText3 Linux最新版