美文网首页
实现一个简单jQuery的API

实现一个简单jQuery的API

作者: 遠_ | 来源:发表于2018-05-31 17:53 被阅读0次

jQuery的基本设计思想和主要用法,就是"选择某个网页元素,然后对其进行某种操作"。
使用jQuery的第一步,往往就是将一个选择表达式,放进构造函数jQuery()(简写为$),然后得到被选中的元素。


下面就讲述了如何实现一个jQuery的API。
通过这个问题来讲述:

window.jQuery = ???
window.$ = jQuery

var $div = $('div')
$div.addClass('red') // 可将所有 div 的 class 添加一个 red
$div.setText('hi') // 可将所有 div 的 textContent 变为 hi

先说答案吧!!!
上面???的内容为:

function(node) {
   var findNode = document.querySelectorAll(node)
        return {         
            addClass: function (addClassName) {               
                for (let i = 0; i < findNode.length; i++) {
                    findNode[i].classList.add(addClassName)
                }
            },
            setText: function (text) {        
                for (let i = 0; i < findNode.length; i++) {
                    findNode[i].textContent = text
                }
            }
        }
    }

思路如下

我们的需求是通过构造一个新的函数,这个函数返回一个对象,该对象包括两种属性方法,即addClass和setText,便可以使用jQuery构造一个新的node(即$div),随后便可以使用$div调用addClass和setText两个属性。

首先我们在这个函数体的内部声明一个变量findNode,随后可以在下面两种属性方法中调用。


addClass()实现思路
  • 通过外部声明的变量findNode,然后通过document.querySelectorAll(node)找到所有的节点
  • 遍历findNode,给每个节点添加相应的class。

setText()实现思路
  • 通过外部声明的变量findNode,然后通过document.querySelectorAll(node)找到所有的节点
  • 遍历findNode,将每个节点的内容通过textContent方法设置为用户设置的text。

更具体的代码:http://js.jirengu.com/moqur/3/edit?html,css,js,output

相关文章

  • 如何实现一个jQuery的api

    什么是jQuery 实现jQuery的api 实现jQuery的api说起来也很简单,就是对DOM进行封装。话不多...

  • 用原生DOM实现一个jQuery的API

    今天第一次接触jQuery,先简单的实现一个jQuery的API,实现两个方法: addClass() setTe...

  • 简单实现jQuery API

    具体的思路:1.封装一个函数,传入节点或者选择器字符串,可以返回伪数组,伪数组中包含获取到的dom元素==> 对函...

  • 初探jQuery

    jQuery API的实现 自己模拟jQuery的一个API预览:http://js.jirengu.com/pa...

  • 实现一个 jQuery 的 API

    实现一个 jQuery 的 API 实现步骤 命名空间模式 这个模式的调用为jQuery.addClass(ite...

  • 实现一个简单jQuery的API

    jQuery的基本设计思想和主要用法,就是"选择某个网页元素,然后对其进行某种操作"。使用jQuery的第一步,往...

  • jQuery 一个简单API的实现

    需求:写一个jQuery函数,函数的功能如下面描述。传入选择器,为所有符合条件的元素添加样式或改变文本内容。 实现...

  • 简单实现一个jQuery的API

    要实现的目标:使页面中所有的div添加一个class和改变div的textContent。我们给每个div加个名为...

  • 简单实现一个 jQuery 的 API

    一、先总体构建出函数如下 二、获得函数要操作的对象,保持输出结果一致 给node的添加class属性,用forEa...

  • 一个简单jquery api的实现

    如下的代码结构: 需求如下: 思路分析 写一个方法 ,找到这个节点写一个 addClass方法,给节点添加样式写一...

网友评论

      本文标题:实现一个简单jQuery的API

      本文链接:https://www.haomeiwen.com/subject/icfcsftx.html