jquery-然后制定自己的query插件

2024-08-31 22:32

本文主要是介绍jquery-然后制定自己的query插件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      • extend扩展插件
      • extend通用写法
      • 登陆校验插件版
      • 登陆校验插件升级版本

extend扩展插件

jQuery.extend(object)
jQuery的命名空间下添加新的功能。多用于插件开发者向 jQuery 中添加新函数时使用。

jQuery.fn.extend(object)
一个对象的内容合并到jQuery的原型,以提供新的jQuery实例方法。

<body><input type="text"><script src="jquery-3.2.1.min.js"></script><script>// 给jQuery扩展方法$.extend({method1:function () {console.log("我喜欢烧热水!");}});// 给jQuery对象扩展方法$.fn.extend({method2: function () {console.log("喜欢喝热水!");}})
</script>
</body>

浏览器测试如下:

$.method1()
我喜欢烧热水!
jquery.html:18:12
undefined$("input").method2()
喜欢喝热水!
jquery.html:24:12
undefined

extend通用写法

扩展如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>jQuery扩展</title>
</head>
<body><input type="text"><script src="jquery-3.2.1.min.js"></script><script>(function () {function f() {console.log("我是来自扩展1里面的f");}$.extend({method: function () {f();}});
})();</script>
</body>
</html>

浏览器测试如下:

$.method()
我是来自扩展1里面的f
jquery.html:16:9
undefined

或者如下的方式:
// 把我这个jQuery插件里面用到的所有变量、函数都封装在一个自执行函数里,这样就不会污染全局作用域
// 又因为$是全局变量,为了防止被修改,我们把jQuery当成参数传到我们的自执行函数中

<script>(function (jq) {function f() {console.log("我是来自扩展2里面的f");}jq.extend({method: function () {f();}});})(jQuery);
</script>

登陆校验插件版

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>登录校验jQuery版</title><style>.error {color: red;}</style>
</head>
<body><form action="" novalidate><div><label for="name">姓名</label><input id="name" type="text" name="username" egon="true" autocomplete="off"><span class="error"></span></div><div><label for="pwd">密码</label><input id="pwd" type="password" name="password" egon="true" autocomplete="off"><span class="error"></span></div><div><label for="mobile">手机</label><input id="mobile" type="text" name="mobile" egon="true" autocomplete="off"><span class="error"></span></div><div><label for="address">地址</label><input id="address" type="text" name="address" autocomplete="off"><span class="error"></span></div><div><input id="submit" type="submit" value="登录"></div>
</form>
<script src="jquery-3.2.1.min.js"></script>
<script src="02-checkPlugin.js"></script>
<!--下面引用很多很多别人写好的jQuery插件-->
<script>$.validate();
</script></body>
</html>

插件代码如下:

/*** Created by Administrator on 2018/1/5.*/(function ($) {$.extend({validate: function () {check();}});function check() {$("form :submit").on("click", function () {// 先把上一次的错误提示信息清空$("form span.error").text("");// 设置一个阻止submit默认提交事件执行的标志位var flag = true;// 开始校验// 1. 找到所有要填写的input$("form input[type!='submit']").each(function () {// this 指的是具体的每一个inputvar inputName = $(this).attr("name");// 取input的值var inputValue = $(this).val();// 取出当前input筐的label文本var inputLabel = $(this).prev().text();var errMsg;  // 提前申明一个错误信息的变量// 1.5 只有必填项才做校验if ($(this).attr("egon")) {// 是必填项// 2. 针对inputVlaue做判断if (inputValue.length === 0) {// 当前这个input没有值errMsg = inputLabel + "不能为空";// 把错误信息填到span标签中$(this).next().text(errMsg);flag = false;return false;  // 跳出each循环}// 如果这个input筐是password,需要多做一个判断:密码位数不能少于6位if (inputName === "password") {if (inputValue.length < 6) {errMsg = inputLabel + "不能少于6位";// 把错误信息填到span标签中$(this).next().text(errMsg);flag = false;return false;  // 跳出each循环}}// 如果inpur框是mobile,需要加一个判断|:判断手机号是不是合法的手机号if (inputName === "mobile") {if (!/^1[345678]\d{9}$/.test(inputValue)) {errMsg = inputLabel + "格式不正确";// 把错误信息填到span标签中$(this).next().text(errMsg);flag = false;return false;  // 跳出each循环}}}});return flag;})
}
})(jQuery);

登陆校验插件升级版本

<script>$.validate({"username": {"required": true},"password": {"required": true, "minLength": 9},"mobile": {"required": true}});
</script>

插件代码如下:

/*** Created by Administrator on 2018/1/5.*/
(function ($) {$.extend({validate: function (arg) {check(arg);}});function check(arg) {$("form :submit").on("click", function () {// 先把上一次的错误提示信息清空$("form span.error").text("");// 设置一个阻止submit默认提交事件执行的标志位var flag = true;// 开始校验// 1. 找到所有要填写的input$("form input[type!='submit']").each(function () {// this 指的是具体的每一个inputvar inputName = $(this).attr("name");// 取input的值var inputValue = $(this).val();// 取出当前input筐的label文本var inputLabel = $(this).prev().text();var errMsg;  // 提前申明一个错误信息的变量// 1.5 只有必填项才做校验if (arg[inputName]  && arg[inputName]["required"]) {// 是必填项// 2. 针对inputVlaue做判断if (inputValue.length === 0) {// 当前这个input没有值errMsg = inputLabel + "不能为空";// 把错误信息填到span标签中$(this).next().text(errMsg);flag = false;return false;  // 跳出each循环}// 如果这个input框是password,需要多做一个判断:密码位数不能少于6位if (inputName === "password") {if (inputValue.length < arg["password"]["minLength"]) {errMsg = inputLabel + "不能少于"+ arg["password"]["minLength"] +"位";// 把错误信息填到span标签中$(this).next().text(errMsg);flag = false;return false;  // 跳出each循环}}// 如果inpur框是mobile,需要加一个判断|:判断手机号是不是合法的手机号if (inputName === "mobile") {if (!/^1[345678]\d{9}$/.test(inputValue)) {errMsg = inputLabel + "格式不正确";// 把错误信息填到span标签中$(this).next().text(errMsg);flag = false;return false;  // 跳出each循环}}}});return flag;})
}
})(jQuery);

这篇关于jquery-然后制定自己的query插件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125173

相关文章

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

maven中的maven-antrun-plugin插件示例详解

《maven中的maven-antrun-plugin插件示例详解》maven-antrun-plugin是Maven生态中一个强大的工具,尤其适合需要复用Ant脚本或实现复杂构建逻辑的场景... 目录1. 核心功能2. 典型使用场景3. 配置示例4. 关键配置项5. 优缺点分析6. 最佳实践7. 常见问题

使用Python和Tkinter实现html标签去除工具

《使用Python和Tkinter实现html标签去除工具》本文介绍用Python和Tkinter开发的HTML标签去除工具,支持去除HTML标签、转义实体并输出纯文本,提供图形界面操作及复制功能,需... 目录html 标签去除工具功能介绍创作过程1. 技术选型2. 核心实现逻辑3. 用户体验增强如何运行

CSS 样式表的四种应用方式及css注释的应用小结

《CSS样式表的四种应用方式及css注释的应用小结》:本文主要介绍了CSS样式表的四种应用方式及css注释的应用小结,本文通过实例代码给大家介绍的非常详细,详细内容请阅读本文,希望能对你有所帮助... 一、外部 css(推荐方式)定义:将 CSS 代码保存为独立的 .css 文件,通过 <link> 标签

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

Vue中插槽slot的使用示例详解

《Vue中插槽slot的使用示例详解》:本文主要介绍Vue中插槽slot的使用示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、插槽是什么二、插槽分类2.1 匿名插槽2.2 具名插槽2.3 作用域插槽三、插槽的基本使用3.1 匿名插槽

springboot+vue项目怎么解决跨域问题详解

《springboot+vue项目怎么解决跨域问题详解》:本文主要介绍springboot+vue项目怎么解决跨域问题的相关资料,包括前端代理、后端全局配置CORS、注解配置和Nginx反向代理,... 目录1. 前端代理(开发环境推荐)2. 后端全局配置 CORS(生产环境推荐)3. 后端注解配置(按接口