您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
javdb清单,替代原网页我的清单,可用作自定义标签
当前为
// ==UserScript== // @name javdb清单 // @namespace http://tampermonkey.net/ // @version 1.0 // @description javdb清单,替代原网页我的清单,可用作自定义标签 // @author lyscop // @grant GM_openInTab // @grant GM_xmlhttpRequest // @grant GM_setValue // @grant GM_getValue // @grant GM_setClipboard // @grant GM_info // @grant GM_openInTab // @grant GM_deleteValue // @grant GM_listValues // @license MIT // @include http*://javdb.com/v/* // @include http*://javdb*.com/v/* // @include http*://javdb.com/actors/* // @include http*://javdb.com/video_codes/* // @include http*://javdb.com/users/lists* // @include http*://javdb.com/users/collection_actors* // @include http*://javdb.com/users/collection_codes* // @run-at document-end // @require https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js // ==/UserScript== (function() { 'use strict'; var image = ''; let d = new Date(); let TimeDateFormatText = '[Year]/[Month]/[Day] [Hour]:[Minute]:[Second]'; let timetext = TimeDateFormatText.replace(/\[YEAR\]/gi, d.getFullYear().toString()).replace(/\[MONTH\]/gi, ('0' +(d.getMonth()+1).toString()).slice(-2)).replace(/\[DAY\]/gi, ('0' +d.getDate().toString()).slice(-2)).replace(/\[HOUR\]/gi, ('0' +d.getHours().toString()).slice(-2)).replace(/\[MINUTE\]/gi, ('0' +d.getMinutes().toString()).slice(-2)).replace(/\[SECOND\]/gi, ('0' +d.getSeconds().toString()).slice(-2)); let videoFanhao = document.querySelector('[data-clipboard-text]').attributes[2].value; let videoTitle = document.getElementsByClassName('current-title')[0].innerHTML; let videoDate = document.getElementsByClassName('panel movie-panel-info')[0].childNodes[3].childNodes[3].innerHTML; let videoUrl = window.location.href; let videoCover = document.getElementsByClassName('video-cover')[0].src; let videoaddDate = timetext; let allValue = GM_listValues(); var inLists = ''; var listsShow = false; var newArray = []; allValue = GM_listValues(); allValue.forEach(function (obj, i) {//数组 var newListEle = {}; newListEle['name'] = obj; newListEle['count'] = Object.values(GM_getValue(obj)).length; newArray.push(newListEle); }); newArray.sort(compare( "count")); newArray.forEach(function (obj, i) {//数组 Object.values(GM_getValue(obj.name)).forEach(function (value, index) {//数组 //console.log(value.fanhao); if(value.fanhao == videoFanhao) { if(inLists == ' ') { inLists = obj.name; } else { inLists = inLists + ' ' + obj.name; } } }); }); // console.log(inLists); if(inLists) { document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML = document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML.trim() + ' ' + inLists; } document.addEventListener('mouseover', function (e) { if(e.target.className === 'button is-info is-outlined button-c') { e.target.style.borderColor = "#b5b5b5"; } }); document.addEventListener('mouseout', function (e) { if(e.target.className === 'button is-info is-outlined button-c') { e.target.style.borderColor = "#dbdbdb"; } }); document.addEventListener('click', function (e) { if(e.target.className === 'button is-info is-outlined button-c') { e.target.blur() } }); const buttonG = document.createElement('button'); document.querySelectorAll('.panel-block div.buttons')[0].appendChild(buttonG); buttonG.classList.add('button', 'is-info', 'is-outlined', 'button-c'); buttonG.innerHTML = '清单'; buttonG.style.borderColor = '#dbdbdb'; buttonG.style.backgroundColor = "#fff"; buttonG.style.color = '#363636'; buttonG.addEventListener('click', () => { listssettings(); window.setTimeout(function(){ listsShow = true; }, 300); }); var nodeEle = document.createElement('div'); nodeEle.id = "Lists"; document.documentElement.appendChild(nodeEle);//元素加入body var wid = window.screen.width/2 - 120; var hei = window.screen.height/2 - 360; var flag = false; function listssettings() { const nodeDiv = document.getElementById("Lists"); nodeDiv.innerHTML = ''; nodeDiv.setAttribute('style', '' + 'position:fixed;' + 'left:' + wid + 'px;' + 'top:'+ hei + 'px;' + 'width:277px;' +//最大宽度 'height:592px;' +//最大高度 'overflow:auto;' + 'font-size:14px!important;' + 'border-radius:5px!important;' + //'border:none;' + //'border:1px solid #ccc!important;' + 'border:1px solid #a9a9a9!important;' + 'background-color:#fff!important;' + 'z-index:2147483647!important;' +//显示最顶层 ''); nodeDiv.style.display = 'block'; var titlenode = document.createElement('div'); titlenode.style.border = '1px'; titlenode.style.marginTop = '8px'; titlenode.style.marginBottom = '8px'; const nameDiv = document.createElement('div'); nameDiv.style.marginLeft = '18px'; nameDiv.style.display = 'inline-block'; nameDiv.innerHTML = '清单 (' + allValue.length + ')'; nameDiv.style.marginRight = '5px'; nameDiv.addEventListener('click', () => { showList('丝袜', 0); }); const addlist = document.createElement('img'); addlist.setAttribute('src', image); addlist.setAttribute('style', '' + 'width:16px;' + 'height:16px;' + 'margin-bottom: 1px;' + 'vertical-align:text-bottom;' + ''); addlist.setAttribute('alt', '新增清单'); addlist.setAttribute('title', '新增清单'); addlist.style.marginRight = '145px'; addlist.addEventListener('click', () => {//新增 var newList = prompt('请输入信息'); var listFlag = false; allValue = GM_listValues(); allValue.forEach(function (obj, i) {//数组 if(newList == obj) listFlag = true; }); if(newList && !listFlag) { GM_setValue(newList, []); listssettings(); showclipboard('新增清单 ' + newList); } else if(!newList) { showclipboard('未输入', 1); } else if(listFlag) { showclipboard('已存在 ' + newList, 0); } }); var close = document.createElement('div'); close.innerHTML = '×'; close.title = 'Close'; close.className = 'close'; close.style.cursor = "pointer"; close.style.display = 'inline-block'; close.style.fontSize = 'initial'; close.style.verticalAlign = 'bottom'; close.addEventListener('click', () => { const settingnodeDiv = document.getElementById("Lists"); settingnodeDiv.style.display = 'none'; listsShow = false; }); close.addEventListener('mouseover', () => { close.style.color = 'red'; }); close.addEventListener('mouseout', () => { close.style.color = 'black'; }); titlenode.appendChild(nameDiv); titlenode.appendChild(addlist); titlenode.appendChild(close); nodeDiv.appendChild(titlenode); const blankLast = document.createElement('div'); blankLast.setAttribute('style', '' + 'height: 7px;' + ''); nodeDiv.appendChild(blankLast); var newEle = {}; var newArray = []; allValue = GM_listValues(); allValue.forEach(function (obj, i) {//数组 var newListEle = {}; newListEle['name'] = obj; newListEle['count'] = Object.values(GM_getValue(obj)).length; newArray.push(newListEle); }); newArray.sort(compare( "count")); newArray.forEach(function (value, i) {//数组 var listsinfo = document.createElement('div'); listsinfo.style.marginLeft = '18px'; var list = document.createElement('span'); var count = document.createElement('span'); var modify = document.createElement('span'); var del = document.createElement('span'); var note = document.createElement('span'); list.innerHTML = value.name; list.style.width = '80px'; list.style.textAlign = 'left'; list.style.cursor = "pointer"; list.style.display = 'inline-block'; Object.values(GM_getValue(value.name)).forEach(function (value1, index1) {//数组 //console.log(value.fanhao); if(value1.fanhao == videoFanhao) { list.style.color = '#48C78E'; list.setAttribute('id', '1'); } }); var ele = GM_getValue(value.name); list.addEventListener('click', () => { if(list.id == 1) { list.style.color = '#000'; list.setAttribute('id', '0'); Object.values(ele).forEach(function (value2, index2) { if(videoFanhao == value2.fanhao) { ele.splice(index2, 1) GM_setValue(value.name, ele); listssettings(); showclipboard('移除清单 ' + value.name, 0); } }); listssettings(); } else { list.setAttribute('id', '1'); newEle['fanhao'] = videoFanhao ; newEle['title'] = videoTitle ; newEle['date'] = videoDate ; newEle['url'] = videoUrl ; newEle['cover'] = videoCover ; newEle['adddate'] = videoaddDate; ele.push(newEle); GM_setValue(value.name, ele); listssettings(); showclipboard('添加至清单 ' + value.name); console.log('Url ' + videoUrl) } }); count.innerHTML = '(' + value.count + ')'; count.className = 'count'; count.style.width = '55px'; count.style.textAlign = 'left'; count.style.cursor = "pointer"; count.style.display = 'inline-block'; count.addEventListener('click', () => { var data = []; data = GM_getValue(value.name); // data = GM_getValue('丝袜'); data.sort(compare1( "fanhao")); showList(data, value.name, value.count); }); modify.innerHTML = '修改'; modify.style.width = '35px'; modify.style.textAlign = 'left'; modify.style.cursor = "pointer"; modify.style.display = 'inline-block'; modify.style.color = 'white'; modify.addEventListener('click', () => { var newobj = prompt('修改 ' + value.name, value.name); let newele = []; var arr = GM_getValue(value.name); newele = arr; if(newobj && newobj != value.name) { GM_deleteValue(value.name); GM_setValue(newobj, newele); showclipboard('修改清单 ' + value.name + '为 ' + newobj, 1); listssettings(); } else { showclipboard('修改失败', 0); } }); modify.addEventListener('mouseover', () => { modify.style.color = 'blue'; }); modify.addEventListener('mouseout', () => { modify.style.color = 'white'; }); del.innerHTML = '删除'; del.style.width = '35px'; del.style.textAlign = 'left'; del.style.cursor = "pointer"; del.style.display = 'inline-block'; del.style.color = 'white'; del.addEventListener('click', () => { var arr = GM_getValue(value.name); if(arr.length == 0) { var result = confirm("是否确认删除清单 " + value.name); if (result) { GM_deleteValue(value.name); showclipboard('删除清单 ' + value.name, 0); listssettings(); } } else { showclipboard('清单番号页面数量不为零,无法删除', 1); } }); del.addEventListener('mouseover', () => { del.style.color = 'red'; }); del.addEventListener('mouseout', () => { del.style.color = 'white'; }); note.innerHTML = '备注'; note.style.width = '35px'; note.style.textAlign = 'left'; note.style.cursor = "pointer"; note.style.display = 'inline-block'; note.style.color = 'white'; note.addEventListener('click', () => { }); note.addEventListener('mouseover', () => { note.style.color = 'green'; }); note.addEventListener('mouseout', () => { note.style.color = 'white'; }); listsinfo.appendChild(list); listsinfo.appendChild(count); listsinfo.appendChild(modify); listsinfo.appendChild(del); listsinfo.appendChild(note); nodeDiv.appendChild(listsinfo); }); nodeDiv.appendChild(blankLast); } var mouseFlag = false; var mouseNode = document.getElementById('Lists'); mouseNode.onmouseenter = function(e){ mouseFlag = true; console.log("ismouseenter"); } mouseNode.onmouseleave = function(){ mouseFlag = false; console.log("ismouseleave"); } document.addEventListener('click', () => { if(listsShow && !mouseFlag) { const settingnodeDiv = document.getElementById("Lists"); settingnodeDiv.style.display = 'none'; listsShow = false; } }); function compare( propertyName) { return function( object1, object2) { var value1 = object1[propertyName]; var value2 = object2[propertyName]; if(value1 < value2) { return 1; } else if(value1 > value2) { return - 1; } else { return 0; } } } function compare1( propertyName) {//番号排序逆序 return function( object1, object2) { var value1 = object1[propertyName]; var value2 = object2[propertyName]; if(value1 > value2) { return 1; } else if(value1 < value2) { return - 1; } else { return 0; } } } var wrapEle = document.createElement('div'); wrapEle.id = "wrap"; wrapEle.setAttribute('style', '' + 'position:fixed;' + 'right:0px;' + 'top:0px;' + 'width:300px;' +//最大宽度 'background-color:rgba(255,255,255,0)!important;' + 'z-index:2147483647!important;' +//显示最顶层 ''); document.documentElement.appendChild(wrapEle);//元素加入body function showclipboard(text, c) { const wrapDiv = document.getElementById("wrap"); var div = document.createElement('div'); if(c == 0) { div.setAttribute('style', '' + 'display:none!important;' +//去掉直接显示 'left:0px;' + 'top:0px;' + 'margin-left:auto;' +//table块靠右显示 'font-size:13px!important;' + 'overflow:auto!important;' + 'background-color:rgba(255,99,71,0.5)!important;' + 'font-family:sans-serif,Arial!important;' + 'font-weight:normal!important;' + 'font-color:rgba(255,255,255,1)!important;' + 'text-align:left!important;' +//左对齐 'color:#fff!important;' +//字体颜色白 'border-radius:3px!important;' + 'border: 1px solid rgb(10 10 10 / 10%) !important;'+ 'max-height:1216px!important;' + 'z-index:2147483647!important;' + ''); } else if(c == 1) { div.setAttribute('style', '' + 'display:none!important;' +//去掉直接显示 'left:0px;' + 'top:0px;' + 'margin-left:auto;' +//table块靠右显示 'font-size:13px!important;' + 'overflow:auto!important;' + 'background-color:rgba(8,46,84,0.6)!important;' + 'font-family:sans-serif,Arial!important;' + 'font-weight:normal!important;' + 'text-align:left!important;' +//左对齐 'color:#fff!important;' + 'border-radius:3px!important;' + 'border: 1px solid rgb(10 10 10 / 10%) !important;'+ 'max-height:1216px!important;' + 'z-index:2147483647!important;' + ''); } else { div.setAttribute('style', '' + 'display:none!important;' +//去掉直接显示 'left:0px;' + 'top:0px;' + 'margin-left:auto;' +//table块靠右显示 'font-size:13px!important;' + 'overflow:auto!important;' + 'background-color:rgba(255,255,255,0.7)!important;' + 'font-family:sans-serif,Arial!important;' + 'font-weight:normal!important;' + 'text-align:left!important;' +//左对齐 'color:#000!important;' + 'border-radius:3px!important;' + 'border: 1px solid rgb(10 10 10 / 10%) !important;'+ 'max-height:1216px!important;' + 'z-index:2147483647!important;' + ''); } div.innerHTML = text; div.style.display = 'table';// 换行显示结果 let fc = wrapDiv.firstElementChild if (fc) { wrapDiv.insertBefore(div,fc) } else { wrapDiv.appendChild(div); } setTimeout(() => { div.parentNode.removeChild(div); },6000) } document.addEventListener('keydown',function(event) { var keynum; if(window.event) // IE keynum = event.keyCode; else if(event.which) // Netscape/Firefox/Opera keynum = event.which; if (event.key === 'Escape') { const settingnodeDiv = document.getElementById("Lists"); settingnodeDiv.style.display = 'none'; listsShow = false; document.getElementById("listpage").style.display = 'none'; } }); var showList = function(data, listname, n) { document.getElementById("Lists").style.display = 'none'; listsShow = false; var nodeEle1 = document.createElement('div'); nodeEle1.id = "listpage"; document.documentElement.appendChild(nodeEle1);//元素加入body var newwid = (window.screen.width - 890)/2; var newhei = (window.screen.height - 860)/2; const newnodeDiv = document.getElementById("listpage"); newnodeDiv.innerHTML = ''; newnodeDiv.setAttribute('style', '' + 'position:fixed;' + 'left:' + newwid + 'px;' + 'top:'+ newhei + 'px;' + 'width:905px;' +//最大宽度 'height:715px;' +//最大高度 'overflow:auto;' + 'font-size:14px!important;' + 'border-radius:5px!important;' + 'border:1px solid #a9a9a9!important;' + 'background-color:#fff!important;' + 'z-index:2147483647!important;' +//显示最顶层 ''); var div0 = document.createElement('div'); var divl = document.createElement('span'); var divc = document.createElement('span'); divl.innerText = listname + ' (' + n + ')'; divl.style.width = "180px"; divl.style.paddingLeft = "6px"; divl.style.display = 'inline-block'; divc.innerHTML = '×'; divc.title = 'Close'; divc.className = 'close'; divc.style.cursor = "pointer"; divc.style.display = 'inline-block'; divc.style.fontSize = 'initial'; divc.style.verticalAlign = 'bottom'; divc.style.marginLeft = '680px'; divc.addEventListener('click', () => { document.getElementById("listpage").style.display = 'none'; }); divc.addEventListener('mouseover', () => { divc.style.color = 'red'; }); divc.addEventListener('mouseout', () => { divc.style.color = 'black'; }); div0.appendChild(divl); div0.appendChild(divc); newnodeDiv.appendChild(div0); var newDiv = document.createElement('div'); newDiv.id = "List"; newDiv.style.paddingLeft = "6px"; newDiv.style.width = '890px'; newDiv.style.display = 'flex'; newDiv.style.flexWrap = 'wrap'; newDiv.style.justifyContent = 'flex-start'; newnodeDiv.appendChild(newDiv); let div = document.getElementById("List"), currentPage = 1, pageCount = 12, list = null, li = null; function paginationByJS(data, div, currentPage, pageCount, list, li) { //拿到我们的总页码 function getTotalPage(data, pageCount){ if (Math.ceil(data.length / pageCount) < 0) return console.error('getTotalPage 出现问题'); return Math.ceil(data.length / pageCount); } //每次都能够返回 一个包含要取到数据的索引 function getArrIndex(currentPage, data, totalPge, pageCount){ let begin, end; if (!currentPage > 0 && !data.length && !totalPge > 0 && !pageCount > 0) { return console.error('您传入的参数有误'); } //当前页在头尾的情况 if (currentPage === 1) { return (totalPge === 1)? { begin: 0, end: data.length - 1 } : { begin: 0, end: pageCount -1 } } if (currentPage === totalPge){ begin = ((currentPage -1) * pageCount); end = data.length -1; return { begin, end } } //在中间的情况 if (currentPage > 1 && currentPage < totalPge){ begin = (currentPage - 1) * pageCount; end = currentPage * pageCount -1; return { begin, end }; } } //增删类名修改 function isActive(){ //拿到目前正在作用active的元素 并且获取他的innerText let activeBtn = document.getElementsByClassName('active')[0], oldActiveIndex = activeBtn? parseInt(activeBtn.innerText) : null; //如果两次点击同一个按钮则不做操作 if (oldActiveIndex === currentPage){ return; } //若按钮存在 么此先做一个删除 if (activeBtn){ activeBtn.classList.remove('active'); } list = Array.from(document.getElementsByTagName('li')); //遍历添加 (list.find(i=> parseInt(i.innerText) === currentPage)).classList.add('active'); var eleli = document.getElementsByTagName('li'); //console.log(eleli) if(eleli) { Object.values(eleli).forEach(function (value, index) {//数组 value.addEventListener('mouseover', () => { value.style.border = '1px solid #d1d1d1'; value.style.padding = '4px'; }); value.addEventListener('mouseout', () => { value.style.border = '0px solid #d1d1d1'; value.style.padding = '5px'; }); // console.log(value.className) if(value.className == 'active') { value.style.background = '#CCE8FF'; } else { value.style.background = '#FFF'; } }); } } //返回渲染数组 function getRenderList(){ let temp = getArrIndex(currentPage, data, getTotalPage(data, pageCount), pageCount); return data.slice(temp.begin, temp.end + 1); //slice方法取头不拿尾 } //第一次创造列表数据 function createBtn(totalPage){ //let ul = document.getElementsByTagName('ul')[0]; var newUl = document.createElement('ul'); newUl.id = "ul-list"; newUl.setAttribute('style', '' + 'padding: 0;' + 'position: relative;' + 'top: 10px;' + //'left: 38%;' + 'overflow: hidden;' + 'list-style: none;' + 'border: 0px solid #c1c1c1;' + 'display: inline-block;' + 'margin-top: 5px;' + 'height: 30px;' + ''); if(getTotalPage(data, pageCount) < 3) { newUl.style.left = '45%'; } else if(getTotalPage(data, pageCount) > 3 && getTotalPage(data, pageCount) < 6) { newUl.style.left = '42%'; } else if(getTotalPage(data, pageCount) > 6 && getTotalPage(data, pageCount) < 8) { newUl.style.left = '40%'; } else { newUl.style.left = '38%'; } newnodeDiv.appendChild(newUl); const ul = document.getElementById("ul-list"); //每次都至少显示五个 当前 当前的前2个 当前的后2个 for (let i =1; i<=totalPage; i++){ //开头 if (i === 1){ li = document.createElement('li'); li.setAttribute('style', '' + 'float: left;' + 'padding: 5px;' + 'color: #273346;' + 'font-size: 15px;' + 'cursor: pointer;' + ''); li.innerText = '<'; ul.appendChild(li); } //拿到页码按钮集合 li = document.createElement('li'); li.setAttribute('style', '' + 'float: left;' + 'padding: 5px;' + 'color: #273346;' + 'font-size: 15px;' + 'cursor: pointer;' + ''); li.innerText = i; //保证至少页码为8的时候才出现省略号 if(i > 6 && totalPage > 7){ li.innerText = '...'; ul.appendChild(li); li = document.createElement('li'); li.setAttribute('style', '' + 'float: left;' + 'padding: 5px;' + 'color: #273346;' + 'font-size: 15px;' + 'cursor: pointer;' + ''); li.innerText = totalPage; ul.appendChild(li); li = document.createElement('li'); li.setAttribute('style', '' + 'float: left;' + 'padding: 5px;' + 'color: #273346;' + 'font-size: 15px;' + 'cursor: pointer;' + ''); li.innerText = '>'; ul.appendChild(li); break; } ul.appendChild(li); //到头了您 if (i === totalPage){ li = document.createElement('li'); li.setAttribute('style', '' + 'float: left;' + 'padding: 5px;' + 'color: #273346;' + 'font-size: 15px;' + 'cursor: pointer;' + ''); li.innerText = '>'; ul.appendChild(li); } } } function btnControl(totalPage, currentPage) { //小于7 就直接全部排出来就ok 不用搞这些花里胡哨的 if (totalPage < 8)return; let li, before = currentPage - 2, //头 after = currentPage + 2, //尾巴 list = document.getElementsByTagName('li'), //数据列表 arr = Array.from(list).filter((i)=>{ //实际页码改变的按钮 var index = parseInt(i.innerText); return (index !== 1 && index !== totalPage && index.toString() !== 'NaN'); }), headFlag = list[2], endFlag = list[list.length - 3]; //控制插入 '...' // if (currentPage > 4 && headFlag.innerText !== '...'){ // li = document.createElement('li'); // li.setAttribute('style', '' + // 'float: left;' + // 'padding: 5px;' + // 'color: #273346;' + // 'font-size: 15px;' + // 'cursor: pointer;' + // ''); // li.innerText = '...'; // list[0].parentElement.insertBefore(li, headFlag); // } // if ((currentPage > 1) && endFlag.innerText !== '...'){ // li = document.createElement('li'); // li.setAttribute('style', '' + // 'float: left;' + // 'padding: 5px;' + // 'color: #273346;' + // 'font-size: 15px;' + // 'cursor: pointer;' + // ''); // li.innerText = '...'; // list[0].parentElement.insertBefore(li, list[list.length - 2]); //加入之前的所以是 list.length-2 // } //控制删除 '...' if (currentPage < 5 && headFlag.innerText === '...'){ headFlag.parentNode.removeChild(headFlag); } if (after + 1 >= totalPage && endFlag.innerText === '...'){ endFlag.parentNode.removeChild(endFlag); } //关键的控制 基于他们展示时当前页 和 头尾 在边界位置以及普通位置的情况来做考虑 //在中间的时候 以currentPage为中心 前后2格 if (before > 1 && after < totalPage){ for (let i = currentPage - 2, j = 0; i <= currentPage + 2; i++, j++){ arr[j].innerText = i; } } //头碰到边界了 说明要从2开始 这个currentPage是3了 if (before === 1){ for (let i = currentPage - 1, j = 0; i <= currentPage + 3; i++, j++){ arr[j].innerText = i; } } //尾巴碰到边界了 说明要从currentPage回头数三个开始,不然会生成一个和totalPage相同的page,就是bug了。 if (after === totalPage){ for (let i = currentPage - 3, j = 0; i < currentPage + 2; i++, j++){ arr[j].innerText = i; } } //当前页首尾~同上 if (currentPage === 1){ for (let i = currentPage + 1, j = 0; i <= arr.length + 1; i++, j++){ arr[j].innerText = i; } } if (currentPage === totalPage){ for (let i = currentPage - arr.length, j = 0; i < totalPage; i++, j++){ arr[j].innerText = i; } } } window.setTimeout(function(){ var eleli = document.getElementsByTagName('li'); //console.log(eleli) if(eleli) { Object.values(eleli).forEach(function (value, index) {//数组 value.addEventListener('mouseover', () => { value.style.border = '1px solid #d1d1d1'; value.style.padding = '4px'; }); value.addEventListener('mouseout', () => { value.style.border = '0px solid #d1d1d1'; value.style.padding = '5px'; }); // console.log(value.className) if(value.className == 'active') { value.style.background = '#CCE8FF'; } }); } }, 100); function arrowControl(target, totalPage){ let event = target || window.event; if (event) { target = event.target; } if (target) { switch (target.innerText){ case '<': currentPage = currentPage === 1? 1 : currentPage - 1;break; case '>': currentPage = currentPage === totalPage? totalPage : currentPage + 1; break; case '...': break; default: currentPage = parseInt(target.innerText); } } } function displayData() { let arr = getRenderList(), p;//最后得到的数据 div.innerHTML = ''; //重置div内容区域 arr.forEach(i =>{ //p = document.createElement('p'); var div1 = document.createElement('div'); var linkimg1 = document.createElement('a'); var img1 = document.createElement('img'); var s1 = document.createElement('div'); var s2 = document.createElement('div'); var delfanhao = document.createElement('div'); div1.style.border = '3px solid #fff'; linkimg1.href = i.url; linkimg1.onclick = function(){ GM_openInTab(i.url, { active: false }); return false; } img1.src = i.cover; img1.style.width = '215px'; s1.innerText = i.fanhao; s2.innerText = i.date; //p.style.padding = '10px'; delfanhao.innerHTML = '删除'; delfanhao.title = '删除'; delfanhao.className = '删除'; delfanhao.style.cursor = "pointer"; delfanhao.style.fontSize = '13px'; delfanhao.style.textAlign = 'center'; delfanhao.addEventListener('click', () => { var ele = GM_getValue(listname); var result1 = confirm("是否确认删除清单 " + listname); if (result1) { Object.values(ele).forEach(function (value, index) { if(i.fanhao == value.fanhao) { //ele = GM_getValue(obj); ele.splice(index, 1) GM_setValue(listname, ele); showclipboard('移除清单 ' + listname, 0); } }); } }); delfanhao.addEventListener('mouseover', () => { delfanhao.style.color = 'red'; }); delfanhao.addEventListener('mouseout', () => { delfanhao.style.color = 'black'; }); linkimg1.appendChild(img1); div1.appendChild(linkimg1); div1.appendChild(s1); div1.appendChild(s2); div1.appendChild(delfanhao); div.appendChild(div1); }); //展示一下 } //这个是事件的监听函数 function pagination(target){ let totalPage = getTotalPage(data, pageCount); //兼容拿到事件 arrowControl(target, totalPage); btnControl(totalPage, parseInt(currentPage)); isActive(); displayData(); } //首次注册生成第一页数据和分页栏 function firstInit() { createBtn(parseInt(getTotalPage(data, pageCount))); isActive(); displayData(); } //window.onload = function () { firstInit(); Array.from(document.getElementsByTagName('li')).forEach(i => i.onclick = function (e) { pagination(e) }); //} } paginationByJS(data, div, currentPage, pageCount, list, li); } })();