封装一个函数
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)
})
}