返回顶部
首页 > 资讯 > 前端开发 > VUE >如何使用jQuery1.6c新增的适配器
  • 730
分享到

如何使用jQuery1.6c新增的适配器

2024-04-02 19:04:59 730人浏览 独家记忆
摘要

这篇文章给大家介绍如何使用Jquery1.6c新增的适配器,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在jQuery的attributes模块(GitHub是这样分割的,但耦合这么高

这篇文章给大家介绍如何使用Jquery1.6c新增的适配器,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

在jQuery的attributes模块(GitHub是这样分割的,但耦合这么高很难说是模块),共增加了三个这样对象,valHooks,attrHooks, propHooks,分别对应val,attr与prop这个三个方法。prop是新增的,表示jQuery决定区分属性与特性的决心,但IE6/7还是无法区分它们,因此attr基本上涵盖了prop的功能。

我们看一下它们各自的运用吧!

// jQuery.style 方法         if ( value !== undefined ) {             //=================略==============           // If a hook was provided, use that value, otherwise just set the specified value             if ( !hooks || !("set" in hooks) || (value = hooks.set( elem, value )) !== undefined ) {               // Wrapped to prevent IE from throwing errors when 'invalid' values are provided               // Fixes bug #5509              try {                 style[ name ] = value;               } catch(e) {}             }              } else {             // If a hook was provided get the non-computed value from there             if ( hooks && "get" in hooks && (ret = hooks.get( elem, false, extra )) !== undefined ) {               return ret;             }          // Otherwise just get the value from the style object            return style[ name ];          }
// jQuery.fn.val 方法          if ( !arguments.length ) {            if ( elem ) {              hooks = jQuery.valHooks[ elem.nodeName.toLowerCase() ] || jQuery.valHooks[ elem.type ];              if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) {                return ret;             }               return (elem.value || "").replace(rreturn, "");            }            return undefined;         }         //===============略============           hooks = jQuery.valHooks[ this.nodeName.toLowerCase() ] || jQuery.valHooks[ this.type ];          // If set returns undefined, fall back to nORMal setting          if ( !hooks || ("set" in hooks && hooks.set( this, val, "value" ) === undefined) ) {            this.value = val;          }
// jQuery.attr 方法         hooks = jQuery.attrHooks[ name ] || ( jQuery.nodeName( elem, "form" ) && formHook );          if ( value !== undefined ) {            if ( value === null || (value === false && !rspecial.test( name )) ) {              jQuery.removeAttr( elem, name );              return undefined;            } else if ( hooks && "set" in hooks && notxml && (ret = hooks.set( elem, value, name )) !== undefined ) {              return ret;            } else {              // Set boolean attributes to the same name             if ( value === true && !rspecial.test( name ) ) {                value = name;              }             elem.setAttribute( name, "" + value );              return value;            }          } else {            if ( hooks && "get" in hooks && notxml ) {              return hooks.get( elem, name );            } else {              ret = elem.getAttribute( name );              // Non-existent attributes return null, we normalize to undefined              return ret === null ? undefined : ret;            }          }
// jQuery.prop 方法               hooks = jQuery.propHooks[ name ];            if ( value !== undefined ) {                if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) {                    return ret;                } else {                    return (elem[ name ] = value);               }            } else {                if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== undefined ) {                    return ret;                } else {                    return elem[ name ];                }            }
//jQuery.event.add          if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) {         // Bind the global event handler to the element            if ( elem.addEventListener ) {              elem.addEventListener( type, eventHandle, false );           } else if ( elem.attachEvent ) {              elem.attachEvent( "on" + type, eventHandle );            }          }    //jQuery.event.remove          if ( !special.teardown || special.teardown.call( elem, namespaces ) === false ) {           jQuery.removeEvent( elem, type, elemData.handle );       }

可以发现还是很有章法的。这些适配器就是用来处理一些特殊的属性,样式或事件。而这些属性,样式或事件,我们可以通过浏览器的特征嗅探,把相应的解决方法添加到适配器中。有了这些适配器,jQuery就可以省去许多if else 判定,当正式版发布时,又可以高兴地宣布这几个方法快了多少百分比了!

可以发现还是很有章法的。这些适配器就是用来处理一些特殊的属性,样式或事件。而这些属性,样式或事件,我们可以通过浏览器的特征嗅探,把相应的解决方法添加到适配器中。有了这些适配器,jQuery就可以省去许多if else 判定,当正式版发布时,又可以高兴地宣布这几个方法快了多少百分比了!

可以发现还是很有章法的。这些适配器就是用来处理一些特殊的属性,样式或事件。而这些属性,样式或事件,我们可以通过浏览器的特征嗅探,把相应的解决方法添加到适配器中。有了这些适配器,jQuery就可以省去许多if else 判定.

关于如何使用jQuery1.6c新增的适配器就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 如何使用jQuery1.6c新增的适配器

本文链接: https://lsjlt.com/news/66374.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何使用jQuery1.6c新增的适配器
    这篇文章给大家介绍如何使用jQuery1.6c新增的适配器,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在jQuery的attributes模块(github是这样分割的,但耦合这么高...
    99+
    2024-04-02
  • es6新增对象如何使用
    本文小编为大家详细介绍“es6新增对象如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“es6新增对象如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、属性的简写ES6中,当对象键名与对应值名相等的...
    99+
    2023-06-30
  • PHP中的数据库适配器如何使用?
    数据库适配器在 php 中是一个设计模式,允许应用程序从底层数据库系统独立地与数据库交互。php 中提供了多个数据库适配器,例如 pdo、mysqli 和 pdo_mysql。要使用数据...
    99+
    2024-05-03
    php 数据库适配器 mysql
  • win10如何连接使用蓝牙适配器
    这篇文章主要介绍win10如何连接使用蓝牙适配器,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!步骤一:安装驱动首先我们要保证蓝牙驱动程序没有问题,一般网友的蓝牙驱动都是Win10自带的,无需自己下载安装,但是也有部分...
    99+
    2023-06-12
  • 如何使用HTML5新增属性data-*
    这篇文章将为大家详细讲解有关如何使用HTML5新增属性data-*,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。HTML5新增属性data-*书写实例<div&nb...
    99+
    2024-04-02
  • Vue3 style中新增的特性如何使用
    本文小编为大家详细介绍“Vue3 style中新增的特性如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue3 style中新增的特性如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。style新特...
    99+
    2023-07-06
  • C#适配器模式的使用
    目录前言适配器模式前言 我昨天做了个梦,我梦见我在一条路走,走的时候经过一个房间,里面关着一条边牧和鸡和猪,后来我醒了,我知道那只边牧就是小叶子(哈仔十一的边牧),小叶子具备牧羊和牧...
    99+
    2024-04-02
  • html5新增的标签如何用
    今天小编给大家分享一下html5新增的标签如何用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。HTML5新增的标签:canv...
    99+
    2023-07-04
  • 如何在Java项目中使用适配器模式
    本篇文章为大家展示了如何在Java项目中使用适配器模式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。适配器一共包括3种角色目标:目标是一个接口,该接口是客户想使用的接口被适配者:被适配者是一个已存在...
    99+
    2023-05-31
    java 适配器模式 ava
  • XamarinAndroid组件中RecylerView适配器如何使用动画
    这篇文章主要介绍XamarinAndroid组件中RecylerView适配器如何使用动画,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!XamarinAndroid组件教程RecylerView适配器使用动画为Rec...
    99+
    2023-06-05
  • 使用rem如何适配移动设备
    使用rem如何适配移动设备?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1. 动态改变 html 的 font-size 值几乎在每个浏览器都将 html 的 ...
    99+
    2023-06-08
  • 如何使用Ping.exe检查Microsoft宽带网络适配器
    要使用Ping.exe检查Microsoft宽带网络适配器,可以按照以下步骤进行操作:1. 打开命令提示符:在Windows操作系统...
    99+
    2023-09-08
    Microsoft
  • 如何使用百度移动适配工具
    这篇文章主要介绍“如何使用百度移动适配工具”,在日常操作中,相信很多人在如何使用百度移动适配工具问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用百度移动适配工具”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-10
  • android中的适配器如何创建
    在Android中,适配器是用于将数据和UI控件(如ListView、RecyclerView等)绑定在一起的桥梁。适配器负责将数据...
    99+
    2023-10-23
    android
  • Vue中使用this.$set()如何新增数据,更新视图
    目录使用this.$set()新增数据,更新视图描述简单的讲就是说说vue.set() (this.$set)用法使用this.$set()新增数据,更新视图 描述 如果在实例创建之...
    99+
    2024-04-02
  • Linux中如何使用useradd命令来新增用户
    小编今天带大家了解Linux中如何使用useradd命令来新增用户,文中知识点介绍的非常详细。觉得有帮助的朋友可以跟着小编一起浏览文章的内容,希望能够帮助更多想解决这个问题的朋友找到问题的答案,下面跟着小编一起深入学习“Linux中如何使用...
    99+
    2023-06-28
  • HTML5如何使用新增的表单元素和属性
    这篇文章将为大家详细讲解有关HTML5如何使用新增的表单元素和属性,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。代码演示说明了HTML5新增的表单元素和属性,演示代码中包...
    99+
    2024-04-02
  • Android SimpleAdapter适配器使用详解
    Android SimpleAdapter使用详解HolderAdapter背景Android的AdapterView用的比较多,ListView,GridView,Spinner等,原生的BaseAdapter对ViewHolder没有支...
    99+
    2023-05-31
    android simpleadapter roi
  • React18新增特性released的使用
    目录新功能:Automatic Batching新功能:Transitions新的Suspense功能新的客户端和服务器Rendering APIsReact DOM ClientR...
    99+
    2024-04-02
  • 使用mybatis新增一条数据返回新增数据的id
    第一种方法 insert into user(userName,password) values(#{userName},#{password}) 注意事项: useGeneratedKeys="true" 表示给主键设...
    99+
    2023-09-20
    java idea 后端 数据库 开发语言 Powered by 金山文档
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作