补全一段jQuery代码

53次阅读

共计 769 个字符,预计需要花费 2 分钟才能阅读完成。

补全下面代码:
window.jQuery = ???
window.$ = jQuery

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

补全后:
window.jQuery = function (nodeOrSelector) {
let nodes = {}

let temp = document.querySelectorAll(nodeOrSelector) // 伪数组
for (let i = 0; i < temp.length; i++) {
nodes[i] = temp[i]
}
nodes.length = temp.length

// 设置所有 div 的 textContent
nodes.setText = function (text) {
for (let i = 0; i < nodes.length; i++) {
nodes[i].textContent = text
}
}
// 为所有 div 添加 class
nodes.addClass = function (className) {
for (let i = 0; i < nodes.length; i++) {
nodes[i].classList.add(className)
}
}

return nodes
}
window.$ = jQuery
var $div = $(‘div’)
$div.addClass(‘red’) // 可将所有 div 的 class 添加一个 red
$div.setText(‘hi’) // 可将所有 div 的 textContent 变为 hi

主要思路是,window.$ = jQuery 所以 window.jQuery 要等于一个函数,这个函数接收一个参数,返回一个对象,返回的对象包含两个方法,这两个方法可以添加 text 文本和添加 class 类

正文完
 0