function createWatchButton(url, isForPlain = false) { let button = document.createElement("button"); button.setAttribute('data-wtmzjk-mag-url', url); if (isForPlain) button.setAttribute('data-wtmzjk-button-for-plain', ''); button.innerHTML = <span>${T.play}</span><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 384 512"><!--! Font Awesome Pro 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2022 Fonticons, Inc. --><path d="M73 39c-14.8-9.1-33.4-9.4-48.5-.9S0 62.6 0 80V432c0 17.4 9.4 33.4 24.5 41.9s33.7 8.1 48.5-.9L361 297c14.3-8.7 23-24.2 23-41s-8.7-32.2-23-41L73 39z"/></svg>; return button; } function hasPlainMagUrlThatNotHandled() { let m = document.body.textContent.match(new RegExp(reg, 'g')); return document.querySelectorAll([data-wtmzjk-button-for-plain]).length != (m ? m.length : 0); }解释每行代码的意思
时间: 2023-06-18 20:07:43 浏览: 121
highlightjs-copy-button.js:Highlight.js https的复制按钮插件
这段代码是用 JavaScript 编写的,主要实现了创建一个用于观看视频的按钮并判断是否有未处理的普通链接。下面是每行代码的解释:
1. `function createWatchButton(url, isForPlain = false) {`
定义一个名为 `createWatchButton` 的函数,它接受两个参数 `url` 和 `isForPlain`,其中 `isForPlain` 的默认值为 `false`。
2. `let button = document.createElement("button");`
创建一个名为 `button` 的变量,它是一个 HTML 按钮元素。
3. `button.setAttribute('data-wtmzjk-mag-url', url);`
为按钮设置一个名为 `data-wtmzjk-mag-url` 的自定义数据属性,它的值为 `url` 参数。
4. `if (isForPlain) button.setAttribute('data-wtmzjk-button-for-plain', '');`
如果 `isForPlain` 参数为 `true`,则为按钮设置一个名为 `data-wtmzjk-button-for-plain` 的自定义数据属性,它的值为空字符串。
5. `button.innerHTML = <span>${T.play}</span><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 384 512"><!--! Font Awesome Pro 6.2.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2022 Fonticons, Inc. --><path d="M73 39c-14.8-9.1-33.4-9.4-48.5-.9S0 62.6 0 80V432c0 17.4 9.4 33.4 24.5 41.9s33.7 8.1 48.5-.9L361 297c14.3-8.7 23-24.2 23-41s-8.7-32.2-23-41L73 39z"/></svg>;`
设置按钮的 HTML 内容,它包含一个 `<span>` 元素和一个 SVG 图标。
6. `return button;`
返回创建的按钮元素。
7. `function hasPlainMagUrlThatNotHandled() {`
定义一个名为 `hasPlainMagUrlThatNotHandled` 的函数,它没有参数。
8. `let m = document.body.textContent.match(new RegExp(reg, 'g'));`
创建一个名为 `m` 的变量,它是一个正则表达式匹配结果的数组。这里使用了一个未定义的 `reg` 变量,所以这行代码存在错误。
9. `return document.querySelectorAll([data-wtmzjk-button-for-plain]).length != (m ? m.length : 0);`
返回一个布尔值,表示是否存在未处理的普通链接。它通过查询包含自定义数据属性 `data-wtmzjk-button-for-plain` 的元素数量和匹配结果数组的长度来进行比较。
阅读全文