jQuery的大抵完成道理

封装一个函数

function addClass(classes){}//可将一切输入的标签的class增加一个类

再封装一个函数

function setText(text){}//可将一切输入标签的textContent变成text

完成这两个函数

第一个函数addClass()是输入一个类名,给选中的一切标签增加一个类,所以要用到classList.add(),详细完成以下

function addClass(node, classes) {
  var allTag = document.querySelectorAll(node)
  for (let i = 0; i < allTag.length; i++) {
    allTag[i].classList.add(classes)
  }
}

第二个函数setText()输入文本,修正选中标签中的文本,所以要用到textContent(),详细完成效果以下

function setText(node, text) {
  var allTag = document.querySelectorAll(node)
  for (let i = 0; i < allTag.length; i++) {
    allTag[i].textContent = text
  }
}

定名空间

在全局变量中建立一个对象,用来贮存封装后的函数,这就是定名空间(名字前面一致加一个前缀)

window.jQuery = {}
jQuery.addClass = addClass
jQuery.setText = setText

jQuery.addClass('div', 'red')
jQuery.setText('div','hi')

整顿以后

window.jQuery = {}
jQuery.addClass = function(node, classes) {
  var allTag = document.querySelectorAll(node)
  for (let i = 0; i < allTag.length; i++) {
    allTag[i].classList.add(classes)
  }
}
jQuery.setText = function(node, text) {
  var allTag = document.querySelectorAll(node)
  for (let i = 0; i < allTag.length; i++) {
    allTag[i].textContent = text
  }
}

jQuery.addClass('div', 'red')
jQuery.setText('div', 'hi')

将node放到前面

node.addClass(classes)
node.setText(text)

1、 要领一:扩大 Node 接口,直接在 Node.prototype 上加函数

Node.prototype.addClass = function(){
   ...
}
Node.prototype.setText = function(){
   ...
}

2、 要领二:新的接口 BetterNode

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

let node2 = jQuery('div')
node2.addClass('red')
node2.setText('hi')

第二种叫做「无侵入」。

进一步完美

给个缩写而且使其可所以节点或许选择器

window.jQuery = function(nodeOrSelector){
  let nodes = {}
  if(typeof nodeOrSelector === 'string'){
    let temp = document.querySelectorAll(nodeOrSelector)
    for(let i=0;i<temp.length;i++){
      nodes[i]=temp[i]
    }
    nodes.length = temp.length
  }else if(nodeOrSelector instanceof Node){
    nodes = {
      0:nodeOrSelector,
      length:1
    }
  }
  nodes.addClass = function(classes){
    for(let i=0;i<nodes.length;i++){
      nodes[i].classList.add(classes)
    }
  }
  nodes.setText = function(text){
    for(let i=0;i<nodes.length;i++){
      nodes[i].textContent = text
    }
  }
  
  return nodes
}
window.$ = jQuery

var $div = $('div')
$div.addClass('red') // 可将一切 div 的 class 增加一个 red
$div.setText('hi') // 可将一切 div 的 textContent 变成 hi

封装ajax

根据jQuery的思绪封装一个ajax函数

window.jQuery.ajax = function(url, method, body, success, fail) {
    let request = XMLHttpResquest()
    request.open(method, url)
    request.onreadystatechange = () => {
        if (request.readyState === 4) {
            if (request.status >= 200 && request.status < 300) {
                success.call(undefined, request.responseText)
            } else if (request.status >= 400) {
                fail.call(undefined, request)
            }
        }
    }
    request.send(body)
}

晋级一下满足promise划定规矩

window.jQuery.ajax = function({
    url,
    method,
    body,
    headers
}) {
    return new Promise(function(resolve, reject) {
        let request = XMLHttpResquest()
        request.open(method, url)
        for (let key in headers) {
            let value = headers[key]
            request.setRequestHeader(key, value)
        }
        request.onreadystatechange = () => {
            if (request.readyState === 4) {
                if (request.status >= 200 && request.status < 300) {
                    success.call(undefined, request.responseText)
                } else if (request.status >= 400) {
                    fail.call(undefined, request)
                }
            }
        }
        request.send(body)
    })
}
    原文作者:梁广铭
    原文地址: https://segmentfault.com/a/1190000015675598
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞