jQuery 插件开发

news2025/1/15 17:19:07

文章目录

  • jQuery 插件开发
    • 插件概述
    • 常用插件
      • 文本溢出:dotdotdot.js
        • 单行文本省略
        • 多行文本省略
      • 延迟加载:lazyload.js
    • 插件编写
      • 方法类插件
      • 函数类插件

jQuery 插件开发

插件概述

jQuery插件可以理解成是使用jQuery来封装的一个功能或特效。

一般来说,每一个jQuery插件都是放到独立的一个文件中的。常说的引入一个jQuery插件,其实就是引入一个外部JavaScript文件。

常用插件

文本溢出:dotdotdot.js

dotdotdot.js官方地址为http://plugins.jquery.com/dotdotdot/。

单行文本省略

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style type="text/css">
			div {
				width: 200px;
				border: 1px solid red;
				overflow: hidden;
				white-space: nowrap;
				text-overflow: ellipsis;
			}
		</style>
	</head>
	<body>
		<div>
			这些一些内容。这些一些内容。这些一些内容。这些一些内容。这些一些内容。这些一些内容。
		</div>
	</body>
</html>

在这里插入图片描述

多行文本省略

如果想要实现“多行文本”的省略号效果,我们可以使用dotdotdot.js这个jQuery插件。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style type="text/css">
			div {
				width: 200px;
				height: 50px;
				border: 1px solid red;
			}
		</style>
		<script src="js/jquery-1.12.4.min.js"></script>
		<script src="js/jquery.dotdotdot.min.js"></script>
		<script>
			$(function() {
				$("div").dotdotdot();
			})
		</script>
	</head>
	<body>
		<div>
			这些一些内容。这些一些内容。这些一些内容。这些一些内容。这些一些内容。这些一些内容。
		</div>
	</body>
</html>

在这里插入图片描述

延迟加载:lazyload.js

中文文档:http://code.ciaoca.com/jquery/lazyload。

github文档:https://github.com/tuupola/jquery_lazyload。

例如进入某个页面时,页面上会有很多图片,有些图片在下面,当我们没有看完整个页面时,那么下面的图片对我们来说就是“没用”的,加载了也是白加载,而且还会降低页面整体的加载速度。

在jQuery中,我们可以使用lazyload.js这个插件来实现图片的延迟加载。也就是只有当我们把滚动条拉到某个位置,相应处的图片才会显示出来,否则就不会显示。

步骤

  1. 引入jQuery库和lazyload.js插件。
  2. 使用data-original替代src。
  3. 调用lazyload()方法。

使用

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style type="text/css">
			div {
				height: 800px;
				background-color: grey;
			}
		</style>
		<script src="js/jquery-1.12.4.min.js"></script>
		<script src="js/jquery.lazyload.min.js"></script>
		<script>
			$(function() {
				$("img").lazyload(function() {
					effect: "fadeIn"
				});
			})
		</script>
	</head>
	<body>
		<div></div>
		<img data-original="img/a.png">
		<img data-original="img/b.png">
		<img data-original="img/c.png">
		<img data-original="img/d.png">
		<img data-original="img/e.png">
	</body>
</html>

插件编写

方法类插件

语法

(function($){
    $.fn.extend({ 
        "插件名": function(参数){ 
            …… 
        } 
    }); 
})(jQuery); 

简单使用

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script src="js/jquery-1.12.4.min.js"></script>
		<script>
			(function() {
				$.fn.extend({
					"hoverChangeColor": function(fgColor, bgColor) {
						$(this).mouseover(function() {
								$(this).css({
									"color": fgColor,
									"background-color": bgColor
								});
							})
							.mouseout(function() {
								$(this).css({
									"color": "black",
									"background-color": "white"
								});
							});
						return $(this);
					}
				})
			})(jQuery);
		</script>
		<script>
			$(function() {
				$("h3").hoverChangeColor("red", "#010101");
			})
		</script>
	</head>
	<body>
		<h3>hello world!</h3>
	</body>
</html>

在这里插入图片描述

添加默认值

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script src="js/jquery-1.12.4.min.js"></script>
		<script>
			(function() {
				$.fn.extend({
					"hoverChangeColor": function(options) {
						var defautls = {
							fgColor: "hotpink",
							bgColor: "lightskyblue"
						};
						var options = $.extend(defautls, options)
						$(this).mouseover(function() {
								$(this).css({
									"color": options.fgColor,
									"background-color": options.bgColor
								});
							})
							.mouseout(function() {
								$(this).css({
									"color": "black",
									"background-color": "white"
								});
							});
						return $(this);
					}
				})
			})(jQuery);
		</script>
		<script>
			$(function() {
				$("h3").hoverChangeColor();
			})
		</script>
	</head>
	<body>
		<h3>hello world!</h3>
	</body>
</html>

$.extend(defautls, options)合并2个对象,将右边的对象合并到左边的对象上。

函数类插件

语法

(function($){
    $.extend({ 
        "插件名": function(){ 
            …… 
        } 
    }); 
})(jQuery) 

使用

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script src="js/jquery-1.12.4.min.js"></script>
		<script>
			(function($) {
				$.extend({
					"maxNum": function(m, n) {
						return (m > n) ? m : n;
					}
				});
			})(jQuery)
			$(function() {
				var result = $.maxNum(10, 5)
				console.log("最大值是:" + result);
			})
		</script>
	</head>
	<body>
	</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/110040.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【我亲身经历的2022年软件质量工作】

软件危机&#xff08;softwarecrisis&#xff09;&#xff0c;20世纪60年代以前&#xff0c;计算机刚刚投入实际使用&#xff0c;软件设计往往只是为了一个特定的应用而在指定的计算机上设计和编制&#xff0c;采用密切依赖于计算机的机器代码或汇编语言&#xff0c;软件的规模…

如何避免编程从入门到放弃?

写代码不是什么太需要创造力的劳动&#xff0c;现在的代码从业者本质上与工业时代的纺织工人没什么差异。大多数人写代码也并不是真的有兴趣&#xff0c;只不过金钱的诱惑使然&#xff0c;这没什么不好&#xff0c;也十分正确。 但对于零基础转行编程的人来说&#xff0c;坚持下…

关于居住办公人口的统计技术解决方案

在数字化转型的浪潮下&#xff0c;大数据产业作为城市数字化转型的重要助力&#xff0c;带来了城市管理手段、模式、理念的深刻变革与创新。为了更好地了解国家城镇的职住分布结构&#xff0c;帮助城市管理部门制定更加合理的规划策略&#xff0c;为城市商业产业提供有效的规划…

面向对象的软件工程

面向对象的软件工程1 面向对象的演化1.1 生活中复杂系统的特点1.2 软件系统的复杂性1.2.1 复杂性的四个方面1.2.1.1 问题域的复杂性1.2.1.2 管理开发的困难性1.2.1.3 软件中的灵活性1.2.1.4 描述离散系统行为1.2.2 复杂系统的五个属性1.2.2.1 层次结构1.2.2.1.1 对象结构1.2.2.…

更改Docker容器网络地址

查看docker 网络列表 查看网络详情 查看容器信息&#xff0c;容器的ip docker inspect 容器id1.创建自定义网络&#xff08;默认是桥接模式&#xff09; 方式1&#xff1a; docker network create 网络名称方式2&#xff1a;指定IP和网关 docker network create --subnet17…

Django中继承父模版时子模板未继承父模板中的动态数据

解决办法&#xff1a; 自己定义一个 context_processors.py 其中的内容根据自己需求来&#xff1a; #__author:joy #date: def index(request):meve_data[首页,产品与服务,市场发展,经典案例,解决方案,联系我们]return {"meve_data":meve_data} 值得注意的是 re…

基于R语言、MaxEnt模型融合技术的物种分布模拟、参数优化方法、结果分析制图与论文写作

第一章 理论篇 以问题导入的方式&#xff0c;深 入掌握原理基础什么是 MaxEnt 模型&#xff1f;  MaxEnt 模型的原理是什么&#xff1f;有哪些用途&#xff1f;  MaxEnt 运行需要哪些输入文件&#xff1f;注意那些事项&#xff1f;  融合 R 语言的 MaxEnt 模型的优势&…

Cortex-A55核心板的温升实测!

HD-G2UL系列核心板是万象奥科全新发布的极具性价比产品&#xff0c;搭载64位Cortex-A551.0GHz处理器&#xff0c;搭配1G内存/8G存储售价仅为148元。本文将针对该系列核心板进行温升实测。 1. 测试准备 HDG2UL-IOT开发板&#xff0c;基于HD-G2UL-CORE工业级核心板设计&#xff0…

2022年安徽最新交安安全员考试模拟题及答案

百分百题库提供交安安全员考试试题、交安安全员考试真题、交安安全员证考试题库等&#xff0c;提供在线做题刷题&#xff0c;在线模拟考试&#xff0c;助你考试轻松过关。 15.为防止电焊弧光伤害眼睛&#xff0c;应采取的防护方式是使用&#xff08;&#xff09;。 A.墨镜 B.…

SAP UI5 Smart Table 和 Smart Filter Bar 的联合使用方法介绍

SmartTable 的 _onMetadataInitialised 方法里&#xff1a; 如果标志位 bIsInitialised 已经赋值&#xff0c;说明已经初始化过了&#xff0c;直接返回。 这里说明 SmartTable 有一个自动调整宽度的属性设置&#xff1a;getEnableAutoColumnWidth 拿到 Table view 的metadat…

c站top1全栈接口测试教程 postman接口测试 接口自动化测试全套教程

本文适合已经掌握 Postman 基本用法的读者&#xff0c;即对接口相关概念有一定了解、已经会使用 Postman 进行模拟请求等基本操作&#xff0c;文章末尾也搭配了相应的视频教程&#xff0c;如果喜欢的同学呢可以来个一键三连哈。 工作环境与版本&#xff1a; Window 7&#xff…

0.96寸OLED显示屏介绍续

0.96 寸OLED 显示屏使用方法 &#xff08;以中景园电子的0.96 寸OLED 显示屏为例&#xff09; 0.96寸OLED显示屏实物图 七针SPI/IIC 0.96寸OLED显示屏使用方法&#xff1a; 七针SPI/IIC 0.96寸OLED显示屏共有七个管脚&#xff0c;1&#xff5e;7 分别为 GDN、VCC、D0、D1、RES、…

FineReport企业数据图表-JS实现参数控件赋值

1. 概述 1.1 版本 报表服务器版本 功能变更 11.0 -- 1.2 问题描述 参数界面中&#xff0c;往往需要在一个控件中动态的控制其他控件的值&#xff0c;如下图&#xff0c;当 username 有值时&#xff0c;state 自动变为 1&#xff0c;当 username 无值时&#xff0c;state 自…

Android-桌面小组件RemoteViews播放动画

一、前言 前段时间什么比较火&#xff1f;当然是木鱼了&#xff0c;木鱼一敲&#xff0c;烦恼全消~在这个节奏越来越快的社会上&#xff0c;算是一个不错的解压利器! 我们也紧跟时事&#xff0c;推出了 我要敲木鱼&#xff08;各大市场均可以下载哦~&#xff09; 咳咳&…

Conv2Former: A Simple Transformer-Style ConvNet for Visual Recognition

论文: https://arxiv.org/pdf/2211.11943.pdf code(pytorh版本): https://github.com/shanglianlm0525/PyTorch-Networks Conv2Former: A Simple Transformer-Style ConvNet for Visual Recognition一、引言二、架构实现(一)、Convolutional Modulation Block&#xff08;二&am…

ICV:车载毫米波雷达市场有望在2023年突破45亿美元!

全球前沿科技咨询机构ICV近期发布了全球车载毫米波雷达的市场分析报告&#xff0c;ICV在报告中表示毫米波角雷达的渗透率有较大上升空间&#xff0c;另外MMIC装配数量的提升可能会是毫米波雷达当前一个主要的技术发展趋势。 本报告旨在评估车载毫米波雷达的市场情况&#xff0c…

vue3路由切换过渡动画实现(含有一些坑)

今天写项目的准备收尾的时候&#xff0c;想给路由组件切换给一个过渡效果。在开发的过程中遇到一些坑。 1.Vue2和Vue3区别 vue2 <transition :name"transitionName"> <router-view></router-view> </transition> 后面就是写样式 Vue3 …

旅游网项目

技术选型 JAVA版本&#xff1a;JDK11数据库&#xff1a;Mysql5.7Navicat后端框架&#xff1a;SpringBoot2.7.1 SpringMVC Mybatis-Plus3.5.0权限控制&#xff1a;SpringSecurity前端框架&#xff1a;AdminLTE2模板引擎&#xff1a;Thymeleaf工具类&#xff1a;发邮件工具类、…

一分钟玩转RPA——word批量转pdf

大家好&#xff0c;我是无用兄&#xff0c;批量word转pdf文件我们在工作中有时会经常遇到&#xff0c;网上也有很多工具&#xff0c;有收费的也有免费的&#xff0c;今天我们主要介绍下如何用影刀RPA工具只需要四条指令就可以完成这个工作&#xff0c;而且后续的使用是完全免费…

解决原 Unique Key 模型存在的问题

为了解决原 Unique Key 模型存在的问题&#xff0c;以更好的满足业务场景的需求&#xff0c;我们决定对 Unique Key 模型进行优化&#xff0c;针对读写效率问题的优化方案展开了详细的调研。 关于以上问题的解决方案&#xff0c;业内已经有了较多的探索。代表性的有三类&#…