Sleazy Fork is available in English.

jav清单

jav清单,替代原网页我的清单,可用作自定义标签

  1. // ==UserScript==
  2. // @name jav清单
  3. // @namespace http://tampermonkey.net/
  4. // @version 1.5
  5. // @description jav清单,替代原网页我的清单,可用作自定义标签
  6. // @author lyscop
  7. // @grant GM_openInTab
  8. // @grant GM_xmlhttpRequest
  9. // @grant GM_setValue
  10. // @grant GM_getValue
  11. // @grant GM_setClipboard
  12. // @grant GM_info
  13. // @grant GM_openInTab
  14. // @grant GM_deleteValue
  15. // @grant GM_listValues
  16. // @license MIT
  17. // @include *://*javdb*.com/*
  18. // @include *://*javdb*.com/v/*
  19. // @include *://javdb*.com/actors/*
  20. // @include *://*javdb*.com/users/lists*
  21. // @include *://*javdb*.com/users/collection_actors*
  22. // @include /^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/
  23. // @include *://www.javbus.com/*
  24. // @include *://javdb*.com/v/*
  25. // @include *://javdb*.com/search?q=*
  26. // @include *://www.javdb.com/*
  27. // @include *://*.javlib.com/*
  28. // @include *://*.javlibrary.com/*
  29. // @include *://*/cn/?v=jav*
  30. // @include *://*/en/?v=jav*
  31. // @include *://*/tw/?v=jav*
  32. // @include *://*/ja/?v=jav*
  33. // @include *://*.javlib.com/*
  34. // @include *://*.javlibrary.com/*
  35. // @include *://*/tw/movie/jav*
  36. // @run-at document-end
  37. // @require https://cdn.jsdelivr.net/npm/jquery@2.2.3/dist/jquery.min.js
  38. // ==/UserScript==
  39.  
  40.  
  41. (function() {
  42.  
  43. 'use strict';
  44.  
  45.  
  46. var image = '';
  47.  
  48. let d = new Date();
  49. let TimeDateFormatText = '[Year]/[Month]/[Day] [Hour]:[Minute]:[Second]';
  50. 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));
  51.  
  52. var origninfo;
  53.  
  54. let videoFanhao;
  55. let videoTitle;
  56. let videoName;
  57. let videoDate;
  58. let videoCover;
  59. let videoUrl = window.location.href;
  60. let videoaddDate = timetext;
  61.  
  62. if(videoUrl.indexOf('javdb') > -1) {
  63. origninfo = document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML.trim();
  64. videoFanhao = document.querySelector('[data-clipboard-text]').attributes[2].value;
  65. videoTitle = document.getElementsByClassName('current-title')[0].innerHTML;
  66. videoDate = document.getElementsByClassName('panel movie-panel-info')[0].childNodes[3].childNodes[3].innerHTML;
  67. videoCover = document.getElementsByClassName('video-cover')[0].src;
  68. } else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
  69. videoFanhao = document.getElementsByClassName('col-md-3 info')[0].children[0].children[1].innerHTML;
  70. videoTitle = document.getElementsByTagName('h3')[0].innerHTML.slice(document.getElementsByTagName('h3')[0].innerHTML.indexOf(' ') + 1);
  71. videoDate = document.getElementsByClassName('col-md-3 info')[0].children[1].innerText.split(': ')[1];
  72. videoCover = document.getElementsByClassName('bigImage')[0].children[0].src;
  73. } else if(videoUrl.indexOf('javlib') > -1) {
  74. videoFanhao = document.getElementById('video_id').children[0].children[0].children[0].children[1].innerHTML;
  75. videoTitle = document.getElementsByClassName('post-title text')[0].children[0].innerHTML.slice(document.getElementsByClassName('post-title text')[0].children[0].innerHTML.indexOf(' ') + 1);
  76. videoDate = document.getElementById('video_date').children[0].children[0].children[0].children[1].innerHTML;
  77. videoCover = document.getElementById('video_jacket_img').src;
  78. }
  79.  
  80. let allValue = GM_listValues();
  81. var inLists = '';
  82. var listsShow = false;
  83.  
  84. var newArray = [];
  85.  
  86. const buttonG = document.createElement('button');
  87.  
  88. if(videoUrl.indexOf('javdb') > -1) {
  89. buttonG.style.borderColor = '#dbdbdb';
  90. buttonG.style.backgroundColor = "#fff";
  91. buttonG.style.color = '#363636';
  92. document.querySelectorAll('.panel-block div.buttons')[0].appendChild(buttonG);
  93. buttonG.classList.add('button', 'is-info', 'is-outlined', 'button-c');
  94. } else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
  95. var divBus = document.getElementsByClassName('col-md-3 info')[0];
  96. console.log(divBus)
  97. var inlistDiv = document.createElement('div');
  98. buttonG.style.border = '1px solid #d1d1d1';
  99. buttonG.style.backgroundColor = "#fff";
  100. buttonG.style.marginBottom = '10px';
  101. divBus.appendChild(buttonG);
  102.  
  103. inlistDiv.className = 'inListBus'
  104. inlistDiv.style.marginBottom = '10px';
  105. divBus.appendChild(inlistDiv);
  106. } else if(videoUrl.indexOf('javlib') > -1) {
  107. var divLibs = document.getElementById('video_favorite_edit');
  108. var inlistSpan = document.createElement('span');
  109. var spanLib = document.createElement('span');
  110. inlistSpan.className = "favoritetype";
  111. buttonG.className = 'smallbutton';
  112. inlistSpan.appendChild(buttonG);
  113. divLibs.appendChild(inlistSpan);
  114.  
  115. spanLib.className = "favoritetype";
  116. divLibs.appendChild(spanLib);
  117. }
  118.  
  119. buttonG.innerHTML = '清单';
  120.  
  121. buttonG.addEventListener('click', () => {
  122. listssettings();
  123. window.setTimeout(function(){
  124. listsShow = true;
  125. }, 300);
  126.  
  127. });
  128.  
  129. allValue = GM_listValues();
  130. allValue.forEach(function (obj, i) {//数组
  131. var newListEle = {};
  132.  
  133. newListEle['name'] = obj;
  134. newListEle['count'] = Object.values(GM_getValue(obj)).length;
  135. newArray.push(newListEle);
  136. });
  137. newArray.sort(compare( "count"));
  138.  
  139. newArray.forEach(function (obj, i) {//数组
  140. Object.values(GM_getValue(obj.name)).forEach(function (value, index) {//数组
  141. //console.log(value.fanhao);
  142. if(value.fanhao == videoFanhao) {
  143. if(inLists == ' ') {
  144. inLists = obj.name;
  145. } else {
  146. inLists = inLists + '  ' + obj.name;
  147. }
  148. }
  149. });
  150. });
  151. // console.log(inLists);
  152. if(inLists) {
  153. if(videoUrl.indexOf('javdb') > -1) {
  154. document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML = origninfo + '   ' + inLists;
  155. } else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
  156. document.getElementsByClassName('inListBus')[0].innerHTML = inLists;
  157. } else if(videoUrl.indexOf('javlib') > -1) {
  158. document.getElementsByClassName('col-md-3 info')[0].innerHTML = inLists;
  159. }
  160. }
  161.  
  162. document.addEventListener('mouseover', function (e) {
  163. if(e.target.className === 'button is-info is-outlined button-c') {
  164. e.target.style.borderColor = "#b5b5b5";
  165. }
  166. });
  167. document.addEventListener('mouseout', function (e) {
  168. if(e.target.className === 'button is-info is-outlined button-c') {
  169. e.target.style.borderColor = "#dbdbdb";
  170. }
  171. });
  172. document.addEventListener('click', function (e) {
  173. if(e.target.className === 'button is-info is-outlined button-c') {
  174. e.target.blur()
  175. }
  176. });
  177.  
  178.  
  179. var nodeEle = document.createElement('div');
  180. nodeEle.id = "Lists";
  181.  
  182. document.documentElement.appendChild(nodeEle);//元素加入body
  183.  
  184. var wid = window.screen.width/2 - 120;
  185. var hei = window.screen.height/2 - 360;
  186. var flag = false;
  187.  
  188. function listssettings() {
  189. const nodeDiv = document.getElementById("Lists");
  190. nodeDiv.innerHTML = '';
  191.  
  192. nodeDiv.setAttribute('style', '' +
  193. 'position:fixed;' +
  194. 'left:' + wid + 'px;' +
  195. 'top:'+ hei + 'px;' +
  196. 'width:277px;' +//最大宽度
  197. 'height:592px;' +//最大高度
  198. 'overflow:auto;' +
  199. 'font-size:14px!important;' +
  200. 'border-radius:5px!important;' +
  201. //'border:none;' +
  202. //'border:1px solid #ccc!important;' +
  203. 'border:1px solid #a9a9a9!important;' +
  204. 'background-color:#fff!important;' +
  205. 'z-index:2147483647!important;' +//显示最顶层
  206. '');
  207. nodeDiv.style.display = 'block';
  208.  
  209.  
  210. var titlenode = document.createElement('div');
  211.  
  212. titlenode.style.border = '1px';
  213. titlenode.style.marginTop = '8px';
  214. titlenode.style.marginBottom = '8px';
  215.  
  216. const nameDiv = document.createElement('div');
  217.  
  218. nameDiv.style.marginLeft = '18px';
  219. nameDiv.style.display = 'inline-block';
  220. nameDiv.innerHTML = '清单 (' + allValue.length + ')';
  221. nameDiv.style.marginRight = '5px';
  222. nameDiv.addEventListener('click', () => {
  223. //showList('丝袜', 0);
  224.  
  225. });
  226.  
  227. const addlist = document.createElement('img');
  228.  
  229. addlist.setAttribute('src', image);
  230. addlist.setAttribute('style', '' + 'width:16px;' + 'height:16px;' + 'margin-bottom: 1px;' + 'vertical-align:text-bottom;' + '');
  231. addlist.setAttribute('alt', '新增清单');
  232. addlist.setAttribute('title', '新增清单');
  233. addlist.style.marginRight = '90px';
  234. addlist.addEventListener('click', () => {//新增
  235. var newList = prompt('请输入信息');
  236. var listFlag = false;
  237. allValue = GM_listValues();
  238. allValue.forEach(function (obj, i) {//数组
  239. if(newList == obj) listFlag = true;
  240. });
  241. if(newList && !listFlag) {
  242. GM_setValue(newList, []);
  243. listssettings();
  244. showclipboard('新增清单 ' + newList);
  245. } else if(!newList) {
  246. showclipboard('未输入', 1);
  247. } else if(listFlag) {
  248. showclipboard('已存在 ' + newList, 0);
  249. }
  250. });
  251.  
  252. var inputSpan = document.createElement('span');
  253. inputSpan.innerHTML = '导入';
  254. inputSpan.style.color = '#d1d1d1';
  255. inputSpan.style.marginRight = '5px';
  256. inputSpan.style.cursor = "pointer";
  257.  
  258. inputSpan.addEventListener('click', () => {
  259. var input = document.createElement('input');
  260. input.type = 'file';
  261.  
  262. input.addEventListener('change', function(event) {
  263. var file = event.target.files[0];
  264. var reader = new FileReader();
  265. reader.addEventListener('load', function(event) {
  266. var content = event.target.result;
  267. var jsonArray = JSON.parse(content);
  268. console.log(jsonArray); // 输出文件内容
  269. Object.keys(jsonArray).forEach(function (key, index) {//数组
  270. GM_setValue(key, jsonArray[key]);
  271. });
  272. showclipboard('已导入');
  273. });
  274. reader.readAsText(file);
  275. });
  276. input.click();
  277.  
  278. });
  279. inputSpan.addEventListener('mouseover', () => {
  280. inputSpan.style.color = 'black';
  281. });
  282. inputSpan.addEventListener('mouseout', () => {
  283. inputSpan.style.color = '#d1d1d1';
  284. });
  285.  
  286. var outputSpan = document.createElement('span');
  287. outputSpan.innerHTML = '导出';
  288. outputSpan.style.color = '#d1d1d1';
  289. outputSpan.style.marginRight = '10px';
  290. outputSpan.style.cursor = "pointer";
  291.  
  292. outputSpan.addEventListener('click', () => {
  293. var javLists = {};
  294.  
  295. allValue = GM_listValues();
  296. allValue.forEach(function (obj, i) {//数组
  297. javLists[obj] = GM_getValue(obj);
  298. });
  299.  
  300. // var blob = new Blob([JSON.stringify(javLists)], {type:"application/json;charset=utf-8"}).slice(2,-1); //text 内容没有{}不构成json
  301. var blob = new Blob([JSON.stringify(javLists)], {type:"application/json;charset=utf-8"}); //json
  302. var url = URL.createObjectURL(blob);
  303. var elem = document.createElement("a");
  304. elem.href = url;
  305. elem.download = 'javList-Backup-' + timetext;
  306. document.body.appendChild(elem);
  307. elem.click();
  308. document.body.removeChild(elem);
  309.  
  310. showclipboard('已导出');
  311. });
  312. outputSpan.addEventListener('mouseover', () => {
  313. outputSpan.style.color = 'black';
  314. });
  315. outputSpan.addEventListener('mouseout', () => {
  316. outputSpan.style.color = '#d1d1d1';
  317. });
  318.  
  319. var close = document.createElement('div');
  320. close.innerHTML = '×';
  321. close.title = 'Close';
  322. close.className = 'close';
  323. close.style.cursor = "pointer";
  324. close.style.display = 'inline-block';
  325. close.style.fontSize = 'initial';
  326. close.style.verticalAlign = 'bottom';
  327.  
  328. close.addEventListener('click', () => {
  329. const settingnodeDiv = document.getElementById("Lists");
  330. settingnodeDiv.style.display = 'none';
  331. listsShow = false;
  332.  
  333. });
  334. close.addEventListener('mouseover', () => {
  335. close.style.color = 'red';
  336. });
  337. close.addEventListener('mouseout', () => {
  338. close.style.color = 'black';
  339. });
  340.  
  341. titlenode.appendChild(nameDiv);
  342. titlenode.appendChild(addlist);
  343.  
  344. titlenode.appendChild(inputSpan);
  345. titlenode.appendChild(outputSpan);
  346.  
  347. titlenode.appendChild(close);
  348. nodeDiv.appendChild(titlenode);
  349.  
  350. const blankLast = document.createElement('div');
  351. blankLast.setAttribute('style', '' + 'height: 7px;' + '');
  352. nodeDiv.appendChild(blankLast);
  353.  
  354.  
  355. var newEle = {};
  356.  
  357. var newArray = [];
  358. var newinLists = '';
  359.  
  360. allValue = GM_listValues();
  361. allValue.forEach(function (obj, i) {//数组
  362. var newListEle = {};
  363.  
  364. newListEle['name'] = obj;
  365. newListEle['count'] = Object.values(GM_getValue(obj)).length;
  366. newArray.push(newListEle);
  367. });
  368. newArray.sort(compare( "count"));
  369.  
  370. newArray.forEach(function (value, i) {//数组
  371. var listsinfo = document.createElement('div');
  372. listsinfo.style.marginLeft = '18px';
  373. var list = document.createElement('span');
  374. var count = document.createElement('span');
  375. var modify = document.createElement('span');
  376. var del = document.createElement('span');
  377. var note = document.createElement('span');
  378.  
  379. list.innerHTML = value.name;
  380. list.style.width = '80px';
  381. list.style.textAlign = 'left';
  382. list.style.cursor = "pointer";
  383. list.style.display = 'inline-block';
  384. Object.values(GM_getValue(value.name)).forEach(function (value1, index1) {//数组
  385. //console.log(value.fanhao);
  386. if(value1.fanhao == videoFanhao) {
  387. list.style.color = '#48C78E';
  388. list.setAttribute('id', '1');
  389. }
  390. });
  391. var ele = GM_getValue(value.name);
  392. list.addEventListener('click', () => {
  393. if(list.id == 1) {
  394. list.style.color = '#000';
  395. list.setAttribute('id', '0');
  396. Object.values(ele).forEach(function (value2, index2) {
  397. if(videoFanhao == value2.fanhao) {
  398. ele.splice(index2, 1)
  399. GM_setValue(value.name, ele);
  400. listssettings();
  401. showclipboard('移除清单 ' + value.name, 0);
  402.  
  403. newArray.forEach(function (obj, i) {//数组
  404. Object.values(GM_getValue(obj.name)).forEach(function (value, index) {//数组
  405. //console.log(value.fanhao);
  406. if(value.fanhao == videoFanhao) {
  407. if(newinLists == ' ') {
  408. newinLists = obj.name;
  409. } else {
  410. newinLists = newinLists + '  ' + obj.name;
  411. }
  412. }
  413. });
  414. });
  415. console.log(newinLists);
  416. if(videoUrl.indexOf('javdb') > -1) {
  417. document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML = origninfo + '   ' + newinLists;
  418. } else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
  419. document.getElementsByClassName('inListBus')[0].innerHTML = newinLists;
  420. } else if(videoUrl.indexOf('javlib') > -1) {
  421. document.getElementsByClassName('favoritetype')[4].innerHTML = newinLists;
  422. }
  423. }
  424. });
  425. listssettings();
  426. } else {
  427. list.setAttribute('id', '1');
  428. newEle['fanhao'] = videoFanhao;
  429. newEle['title'] = videoTitle;
  430. newEle['date'] = videoDate;
  431. newEle['url'] = videoUrl;
  432. newEle['cover'] = videoCover;
  433. newEle['adddate'] = videoaddDate;
  434. ele.push(newEle);
  435. GM_setValue(value.name, ele);
  436. listssettings();
  437. showclipboard('添加至清单 ' + value.name);
  438. console.log('Url ' + videoUrl);
  439. newArray.forEach(function (obj, i) {//数组
  440. Object.values(GM_getValue(obj.name)).forEach(function (value, index) {//数组
  441. //console.log(value.fanhao);
  442. if(value.fanhao == videoFanhao) {
  443. if(newinLists == ' ') {
  444. newinLists = obj.name;
  445. } else {
  446. newinLists = newinLists + '  ' + obj.name;
  447. }
  448. }
  449. });
  450. });
  451. console.log(newinLists);
  452. if(videoUrl.indexOf('javdb') > -1) {
  453. document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML = origninfo + '   ' + newinLists;
  454. } else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
  455. document.getElementsByClassName('inListBus')[0].innerHTML = newinLists;
  456. } else if(videoUrl.indexOf('javlib') > -1) {
  457. document.getElementsByClassName('favoritetype')[4].innerHTML = newinLists;
  458. }
  459. }
  460.  
  461. });
  462. count.innerHTML = '(' + value.count + ')';
  463. count.className = 'count';
  464. count.style.width = '55px';
  465. count.style.textAlign = 'left';
  466. count.style.cursor = "pointer";
  467. count.style.display = 'inline-block';
  468. count.addEventListener('click', () => {
  469. var data = [];
  470. data = GM_getValue(value.name);
  471. data.sort(compare1("fanhao",0, 0));
  472. showList(data, value.name, value.count, 1);
  473. });
  474.  
  475. modify.innerHTML = '修改';
  476. modify.style.width = '35px';
  477. modify.style.textAlign = 'left';
  478. modify.style.cursor = "pointer";
  479. modify.style.display = 'inline-block';
  480. modify.style.color = 'white';
  481. modify.addEventListener('click', () => {
  482. var newobj = prompt('修改 ' + value.name, value.name);
  483. let newele = [];
  484. var arr = GM_getValue(value.name);
  485. newele = arr;
  486. if(newobj && newobj != value.name) {
  487. GM_deleteValue(value.name);
  488. GM_setValue(newobj, newele);
  489. showclipboard('修改清单 ' + value.name + '为 ' + newobj, 1);
  490.  
  491. listssettings();
  492. } else {
  493. showclipboard('修改失败', 0);
  494. }
  495. });
  496. modify.addEventListener('mouseover', () => {
  497. modify.style.color = 'blue';
  498. });
  499. modify.addEventListener('mouseout', () => {
  500. modify.style.color = 'white';
  501. });
  502.  
  503. del.innerHTML = '删除';
  504. del.style.width = '35px';
  505. del.style.textAlign = 'left';
  506. del.style.cursor = "pointer";
  507. del.style.display = 'inline-block';
  508. del.style.color = 'white';
  509. del.addEventListener('click', () => {
  510. var arr = GM_getValue(value.name);
  511. if(arr.length == 0) {
  512. var result = confirm("是否确认删除清单 " + value.name);
  513. if (result) {
  514. GM_deleteValue(value.name);
  515. showclipboard('删除清单 ' + value.name, 0);
  516. listssettings();
  517. }
  518. } else {
  519. showclipboard('清单番号页面数量不为零,无法删除', 1);
  520.  
  521. }
  522. });
  523. del.addEventListener('mouseover', () => {
  524. del.style.color = 'red';
  525. });
  526. del.addEventListener('mouseout', () => {
  527. del.style.color = 'white';
  528. });
  529.  
  530. note.innerHTML = '备注';
  531. note.style.width = '35px';
  532. note.style.textAlign = 'left';
  533. note.style.cursor = "pointer";
  534. note.style.display = 'inline-block';
  535. note.style.color = 'white';
  536. note.addEventListener('click', () => {
  537.  
  538. });
  539. note.addEventListener('mouseover', () => {
  540. note.style.color = 'green';
  541. });
  542. note.addEventListener('mouseout', () => {
  543. note.style.color = 'white';
  544. });
  545.  
  546. listsinfo.appendChild(list);
  547. listsinfo.appendChild(count);
  548. listsinfo.appendChild(modify);
  549. listsinfo.appendChild(del);
  550. listsinfo.appendChild(note);
  551. nodeDiv.appendChild(listsinfo);
  552. });
  553.  
  554. nodeDiv.appendChild(blankLast);
  555.  
  556. }
  557.  
  558. var mouseFlag = false;
  559. var mouseNode = document.getElementById('Lists');
  560. mouseNode.onmouseenter = function(e){
  561. mouseFlag = true;
  562. console.log("ismouseenter");
  563. }
  564.  
  565. mouseNode.onmouseleave = function(){
  566. mouseFlag = false;
  567. console.log("ismouseleave");
  568. }
  569. document.addEventListener('click', () => {
  570. if(listsShow && !mouseFlag) {
  571. const settingnodeDiv = document.getElementById("Lists");
  572. settingnodeDiv.style.display = 'none';
  573. listsShow = false;
  574. }
  575. });
  576.  
  577. function compare( propertyName) {
  578. return function( object1, object2) {
  579. var value1 = object1[propertyName];
  580. var value2 = object2[propertyName];
  581. if(value1 < value2) {
  582. return 1;
  583. } else if(value1 > value2) {
  584. return - 1;
  585. } else {
  586. return 0;
  587. }
  588. }
  589. }
  590.  
  591. function compare1(propertyName, m, n) {//番号排序逆序
  592. return function( object1, object2) {
  593. var value1;
  594. var value2;
  595. if(m == 0) {
  596. value1 = object1[propertyName];
  597. value2 = object2[propertyName];
  598. } else if(m == 1) {
  599. value1 = new Date(object1[propertyName]);
  600. value2 = new Date(object2[propertyName]);
  601. value1 = value1.getTime();
  602. value2 = value2.getTime();
  603. }
  604. if(n == 0) {//0顺序1逆序
  605. if(value1 > value2) {
  606. return 1;
  607. } else if(value1 < value2) {
  608. return - 1;
  609. } else {
  610. return 0;
  611. }
  612. } else if(n == 1) {
  613. if(value1 < value2) {
  614. return 1;
  615. } else if(value1 > value2) {
  616. return - 1;
  617. } else {
  618. return 0;
  619. }
  620. }
  621. }
  622. }
  623.  
  624. var wrapEle = document.createElement('div');
  625. wrapEle.id = "wrap";
  626. wrapEle.setAttribute('style', '' +
  627. 'position:fixed;' +
  628. 'right:0px;' +
  629. 'top:0px;' +
  630. 'width:300px;' +//最大宽度
  631. 'background-color:rgba(255,255,255,0)!important;' +
  632. 'z-index:2147483647!important;' +//显示最顶层
  633. '');
  634.  
  635. document.documentElement.appendChild(wrapEle);//元素加入body
  636.  
  637. function showclipboard(text, c) {
  638. const wrapDiv = document.getElementById("wrap");
  639. var div = document.createElement('div');
  640. if(c == 0) {
  641. div.setAttribute('style', '' +
  642. 'display:none!important;' +//去掉直接显示
  643. 'left:0px;' +
  644. 'top:0px;' +
  645. 'margin-left:auto;' +//table块靠右显示
  646. 'font-size:13px!important;' +
  647. 'overflow:auto!important;' +
  648. 'background-color:rgba(255,99,71,0.5)!important;' +
  649. 'font-family:sans-serif,Arial!important;' +
  650. 'font-weight:normal!important;' +
  651. 'font-color:rgba(255,255,255,1)!important;' +
  652. 'text-align:left!important;' +//左对齐
  653. 'color:#fff!important;' +//字体颜色白
  654. 'border-radius:3px!important;' +
  655. 'border: 1px solid rgb(10 10 10 / 10%) !important;'+
  656. 'max-height:1216px!important;' +
  657. 'z-index:2147483647!important;' +
  658. '');
  659. } else if(c == 1) {
  660. div.setAttribute('style', '' +
  661. 'display:none!important;' +//去掉直接显示
  662. 'left:0px;' +
  663. 'top:0px;' +
  664. 'margin-left:auto;' +//table块靠右显示
  665. 'font-size:13px!important;' +
  666. 'overflow:auto!important;' +
  667. 'background-color:rgba(8,46,84,0.6)!important;' +
  668. 'font-family:sans-serif,Arial!important;' +
  669. 'font-weight:normal!important;' +
  670. 'text-align:left!important;' +//左对齐
  671. 'color:#fff!important;' +
  672. 'border-radius:3px!important;' +
  673. 'border: 1px solid rgb(10 10 10 / 10%) !important;'+
  674. 'max-height:1216px!important;' +
  675. 'z-index:2147483647!important;' +
  676. '');
  677. } else {
  678. div.setAttribute('style', '' +
  679. 'display:none!important;' +//去掉直接显示
  680. 'left:0px;' +
  681. 'top:0px;' +
  682. 'margin-left:auto;' +//table块靠右显示
  683. 'font-size:13px!important;' +
  684. 'overflow:auto!important;' +
  685. 'background-color:rgba(255,255,255,0.7)!important;' +
  686. 'font-family:sans-serif,Arial!important;' +
  687. 'font-weight:normal!important;' +
  688. 'text-align:left!important;' +//左对齐
  689. 'color:#000!important;' +
  690. 'border-radius:3px!important;' +
  691. 'border: 1px solid rgb(10 10 10 / 10%) !important;'+
  692. 'max-height:1216px!important;' +
  693. 'z-index:2147483647!important;' +
  694. '');
  695. }
  696.  
  697. div.innerHTML = text;
  698. div.style.display = 'table';// 换行显示结果
  699. let fc = wrapDiv.firstElementChild
  700. if (fc) {
  701. wrapDiv.insertBefore(div,fc)
  702. } else {
  703. wrapDiv.appendChild(div);
  704. }
  705. setTimeout(() => {
  706. div.parentNode.removeChild(div);
  707. },6000)
  708.  
  709. }
  710. document.addEventListener('keydown',function(event) {
  711.  
  712. var keynum;
  713. if(window.event) // IE
  714. keynum = event.keyCode;
  715. else if(event.which) // Netscape/Firefox/Opera
  716. keynum = event.which;
  717.  
  718. if (event.key === 'Escape') {
  719. const settingnodeDiv = document.getElementById("Lists");
  720. settingnodeDiv.style.display = 'none';
  721. listsShow = false;
  722. document.getElementById("listpage").style.display = 'none';
  723. }
  724. });
  725.  
  726.  
  727. var showList = function(data, listname, n, s) {
  728.  
  729. document.getElementById("Lists").style.display = 'none';
  730. listsShow = false;
  731.  
  732. var nodeEle1 = document.createElement('div');
  733. nodeEle1.id = "listpage";
  734.  
  735. document.documentElement.appendChild(nodeEle1);//元素加入body
  736.  
  737. var newwid = (window.screen.width - 890)/2;
  738. var newhei = (window.screen.height - 860)/2;
  739. const newnodeDiv = document.getElementById("listpage");
  740. newnodeDiv.innerHTML = '';
  741.  
  742. newnodeDiv.setAttribute('style', '' +
  743. 'position:fixed;' +
  744. 'left:' + newwid + 'px;' +
  745. 'top:'+ newhei + 'px;' +
  746. 'width:905px;' +//最大宽度
  747. 'height:715px;' +//最大高度
  748. 'overflow:auto;' +
  749. 'font-size:14px!important;' +
  750. 'border-radius:5px!important;' +
  751. 'border:1px solid #a9a9a9!important;' +
  752. 'background-color:#fff!important;' +
  753. 'z-index:2147483647!important;' +//显示最顶层
  754. '');
  755.  
  756. var div0 = document.createElement('div');
  757. var divl = document.createElement('span');
  758. var download = document.createElement('span');
  759. var downloadtxt = document.createElement('span');
  760. //var downxls = document.createElement('span');
  761. var downloadjson = document.createElement('span');
  762.  
  763. var sort = document.createElement('span');
  764. var sortfanhao = document.createElement('span');
  765. var sorttimerorder = document.createElement('span');
  766. var sorttimerreversedorder = document.createElement('span');
  767. var sortaddtimerorder = document.createElement('span');
  768. var sortaddtimerreversedorder = document.createElement('span');
  769.  
  770. var divc = document.createElement('span');
  771.  
  772. var stri = '';
  773. var queryi = [];
  774.  
  775. divl.innerText = listname + ' (' + n + ')';
  776. divl.style.width = "180px";
  777. divl.style.paddingLeft = "6px";
  778. divl.style.display = 'inline-block';
  779.  
  780. download.innerHTML = '下载';
  781. download.style.color = '#000';
  782. download.style.marginRight = '10px';
  783.  
  784. downloadtxt.innerHTML = 'TXT';
  785. downloadtxt.style.color = '#d1d1d1';
  786. downloadtxt.style.marginRight = '10px';
  787. downloadtxt.style.cursor = "pointer";
  788. downloadtxt.addEventListener('click', () => {
  789. GM_getValue(listname).forEach(function (value, i) {//数组
  790. queryi.push(value.fanhao + ',' + value.title.trim());
  791. });
  792. queryi.sort();
  793. for(var i=0;i<queryi.length;i++) {
  794. stri = stri + queryi[i] + '\n';
  795. }
  796. var downLinki = document.createElement('a');
  797. downLinki.download = listname;
  798. //字符内容转换为blod地址
  799. var blobi = new Blob([stri]);
  800. downLinki.href = URL.createObjectURL(blobi);
  801. // 链接插入到页面
  802. document.body.appendChild(downLinki);
  803. downLinki.click();
  804. // 移除下载链接
  805. document.body.removeChild(downLinki);
  806.  
  807. showclipboard('已下载TXT');
  808. });
  809. downloadtxt.addEventListener('mouseover', () => {
  810. downloadtxt.style.color = 'black';
  811. });
  812. downloadtxt.addEventListener('mouseout', () => {
  813. downloadtxt.style.color = '#d1d1d1';
  814. });
  815.  
  816. downloadjson.innerHTML = 'JSON';
  817. downloadjson.style.color = '#d1d1d1';
  818. downloadjson.style.marginRight = '10px';
  819. downloadjson.style.cursor = "pointer";
  820. downloadjson.addEventListener('click', () => {
  821. var javLists = {};
  822. javLists[listname] = GM_getValue(listname);
  823.  
  824. var blob = new Blob([JSON.stringify(javLists)], {type:"application/json;charset=utf-8"}); //json
  825. var url = URL.createObjectURL(blob);
  826. var elem = document.createElement("a");
  827. elem.href = url;
  828. elem.download = 'javList-Backup-' + timetext;
  829. document.body.appendChild(elem);
  830. elem.click();
  831. document.body.removeChild(elem);
  832.  
  833. showclipboard('已下载JSON');
  834. });
  835. downloadjson.addEventListener('mouseover', () => {
  836. downloadjson.style.color = 'black';
  837. });
  838. downloadjson.addEventListener('mouseout', () => {
  839. downloadjson.style.color = '#d1d1d1';
  840. });
  841.  
  842. sort.innerHTML = '排序';
  843. sort.style.color = '#000';
  844. sort.style.marginRight = '10px';
  845.  
  846. sortfanhao.innerHTML = '番号顺序';
  847. if(s == 1)
  848. sortfanhao.style.color = '#d1d1d1';
  849. else
  850. sortfanhao.style.color = '#000';
  851. sortfanhao.style.marginRight = '10px';
  852. sortfanhao.style.cursor = "pointer";
  853. sortfanhao.addEventListener('click', () => {
  854. var data = [];
  855. data = GM_getValue(listname);
  856. data.sort(compare1("fanhao",0, 0));
  857. showList(data, listname, n, 1);
  858. });
  859.  
  860. sorttimerorder.innerHTML = '时间顺序';
  861. if(s == 2)
  862. sorttimerorder.style.color = '#d1d1d1';
  863. else
  864. sorttimerorder.style.color = '#000';
  865. sorttimerorder.style.marginRight = '10px';
  866. sorttimerorder.style.cursor = "pointer";
  867. sorttimerorder.addEventListener('click', () => {
  868. var data = [];
  869. data = GM_getValue(listname);
  870. data.sort(compare1("date",1, 0));
  871. showList(data, listname, n, 2);
  872. });
  873.  
  874. sorttimerreversedorder.innerHTML = '时间逆序';
  875. if(s == 3)
  876. sorttimerreversedorder.style.color = '#d1d1d1';
  877. else
  878. sorttimerreversedorder.style.color = '#000';
  879. sorttimerreversedorder.style.marginRight = '10px';
  880. sorttimerreversedorder.style.cursor = "pointer";
  881. sorttimerreversedorder.addEventListener('click', () => {
  882. var data = [];
  883. data = GM_getValue(listname);
  884. data.sort(compare1("date",1, 1));
  885. showList(data, listname, n, 3);
  886. });
  887.  
  888. sortaddtimerorder.innerHTML = '添加顺序';
  889. if(s == 4)
  890. sortaddtimerorder.style.color = '#d1d1d1';
  891. else
  892. sortaddtimerorder.style.color = '#000';
  893. sortaddtimerorder.style.marginRight = '10px';
  894. sortaddtimerorder.style.cursor = "pointer";
  895. sortaddtimerorder.addEventListener('click', () => {
  896. var data = [];
  897. data = GM_getValue(listname);
  898. data.sort(compare1("adddate",1, 0));
  899. showList(data, listname, n, 4);
  900. });
  901.  
  902. sortaddtimerreversedorder.innerHTML = '添加逆序';
  903. if(s == 5)
  904. sortaddtimerreversedorder.style.color = '#d1d1d1';
  905. else
  906. sortaddtimerreversedorder.style.color = '#000';
  907. sortaddtimerreversedorder.style.marginRight = '10px';
  908. sortaddtimerreversedorder.style.cursor = "pointer";
  909. sortaddtimerreversedorder.addEventListener('click', () => {
  910. var data = [];
  911. data = GM_getValue(listname);
  912. data.sort(compare1("adddate",1, 1));
  913. showList(data, listname, n, 5);
  914. });
  915.  
  916.  
  917. divc.innerHTML = '×';
  918. divc.title = 'Close';
  919. divc.className = 'close';
  920. divc.style.cursor = "pointer";
  921. divc.style.display = 'inline-block';
  922. divc.style.fontSize = 'initial';
  923. divc.style.verticalAlign = 'bottom';
  924. divc.style.marginLeft = '215px';
  925.  
  926. divc.addEventListener('click', () => {
  927. document.getElementById("listpage").style.display = 'none';
  928. });
  929. divc.addEventListener('mouseover', () => {
  930. divc.style.color = 'red';
  931. });
  932. divc.addEventListener('mouseout', () => {
  933. divc.style.color = 'black';
  934. });
  935.  
  936. div0.appendChild(divl);
  937. div0.appendChild(download);
  938. div0.appendChild(downloadtxt);
  939. div0.appendChild(downloadjson);
  940. div0.appendChild(sort);
  941. div0.appendChild(sortfanhao);
  942. div0.appendChild(sorttimerorder);
  943. div0.appendChild(sorttimerreversedorder);
  944. div0.appendChild(sortaddtimerorder);
  945. div0.appendChild(sortaddtimerreversedorder);
  946. div0.appendChild(divc);
  947.  
  948. newnodeDiv.appendChild(div0);
  949.  
  950. var newDiv = document.createElement('div');
  951. newDiv.id = "List";
  952. newDiv.style.paddingLeft = "6px";
  953. newDiv.style.width = '890px';
  954. newDiv.style.display = 'flex';
  955. newDiv.style.flexWrap = 'wrap';
  956. newDiv.style.justifyContent = 'flex-start';
  957. newnodeDiv.appendChild(newDiv);
  958. let div = document.getElementById("List"),
  959.  
  960. currentPage = 1,
  961. pageCount = 12,
  962. list = null,
  963. li = null;
  964.  
  965. function paginationByJS(data, div, currentPage, pageCount, list, li) {
  966. //拿到我们的总页码
  967. function getTotalPage(data, pageCount){
  968. if (Math.ceil(data.length / pageCount) < 0) return console.error('getTotalPage 出现问题');
  969. return Math.ceil(data.length / pageCount);
  970. }
  971.  
  972. //每次都能够返回 一个包含要取到数据的索引
  973. function getArrIndex(currentPage, data, totalPge, pageCount){
  974. let begin, end;
  975. if (!currentPage > 0 && !data.length && !totalPge > 0 && !pageCount > 0) {
  976. return console.error('您传入的参数有误');
  977. }
  978. //当前页在头尾的情况
  979. if (currentPage === 1) {
  980. return (totalPge === 1)? {
  981. begin: 0,
  982. end: data.length - 1
  983. } : {
  984. begin: 0,
  985. end: pageCount -1
  986. }
  987. }
  988. if (currentPage === totalPge){
  989. begin = ((currentPage -1) * pageCount);
  990. end = data.length -1;
  991. return {
  992. begin, end
  993. }
  994. }
  995. //在中间的情况
  996. if (currentPage > 1 && currentPage < totalPge){
  997. begin = (currentPage - 1) * pageCount;
  998. end = currentPage * pageCount -1;
  999. return { begin, end };
  1000. }
  1001. }
  1002.  
  1003. //增删类名修改
  1004. function isActive(){
  1005. //拿到目前正在作用active的元素 并且获取他的innerText
  1006. let activeBtn = document.getElementsByClassName('active')[0],
  1007. oldActiveIndex = activeBtn? parseInt(activeBtn.innerText) : null;
  1008.  
  1009.  
  1010.  
  1011. //如果两次点击同一个按钮则不做操作
  1012. if (oldActiveIndex === currentPage){ return; }
  1013.  
  1014. //若按钮存在 么此先做一个删除
  1015. if (activeBtn){ activeBtn.classList.remove('active'); }
  1016.  
  1017. list = Array.from(document.getElementsByTagName('li'));
  1018.  
  1019. //遍历添加
  1020. (list.find(i=> parseInt(i.innerText) === currentPage)).classList.add('active');
  1021.  
  1022. var eleli = document.getElementsByTagName('li');
  1023. //console.log(eleli)
  1024. if(eleli) {
  1025. Object.values(eleli).forEach(function (value, index) {//数组
  1026. value.addEventListener('mouseover', () => {
  1027. value.style.border = '1px solid #d1d1d1';
  1028. value.style.padding = '4px';
  1029. });
  1030. value.addEventListener('mouseout', () => {
  1031. value.style.border = '0px solid #d1d1d1';
  1032. value.style.padding = '5px';
  1033. });
  1034. // console.log(value.className)
  1035. if(value.className == 'active') {
  1036. value.style.background = '#CCE8FF';
  1037. } else {
  1038. value.style.background = '#FFF';
  1039. }
  1040. });
  1041. }
  1042. }
  1043.  
  1044.  
  1045. //返回渲染数组
  1046. function getRenderList(){
  1047. let temp = getArrIndex(currentPage, data, getTotalPage(data, pageCount), pageCount);
  1048. return data.slice(temp.begin, temp.end + 1); //slice方法取头不拿尾
  1049. }
  1050.  
  1051. //第一次创造列表数据
  1052. function createBtn(totalPage){
  1053. //let ul = document.getElementsByTagName('ul')[0];
  1054. var newUl = document.createElement('ul');
  1055. newUl.id = "ul-list";
  1056. newUl.setAttribute('style', '' +
  1057. 'padding: 0;' +
  1058. 'position: relative;' +
  1059. 'top: 10px;' +
  1060. //'left: 38%;' +
  1061. 'overflow: hidden;' +
  1062. 'list-style: none;' +
  1063. 'border: 0px solid #c1c1c1;' +
  1064. 'display: inline-block;' +
  1065. 'margin-top: 5px;' +
  1066. 'height: 30px;' +
  1067. '');
  1068. if(getTotalPage(data, pageCount) < 3) {
  1069. newUl.style.left = '45%';
  1070. } else if(getTotalPage(data, pageCount) > 3 && getTotalPage(data, pageCount) < 6) {
  1071. newUl.style.left = '42%';
  1072. } else if(getTotalPage(data, pageCount) > 6 && getTotalPage(data, pageCount) < 8) {
  1073. newUl.style.left = '40%';
  1074. } else {
  1075. newUl.style.left = '38%';
  1076. }
  1077. newnodeDiv.appendChild(newUl);
  1078. const ul = document.getElementById("ul-list");
  1079. //每次都至少显示五个 当前 当前的前2个 当前的后2个
  1080. for (let i =1; i<=totalPage; i++){
  1081. //开头
  1082. if (i === 1){
  1083. li = document.createElement('li');
  1084. li.setAttribute('style', '' +
  1085. 'float: left;' +
  1086. 'padding: 5px;' +
  1087. 'color: #273346;' +
  1088. 'font-size: 15px;' +
  1089. 'cursor: pointer;' +
  1090. '');
  1091. li.innerText = '<';
  1092. ul.appendChild(li);
  1093. }
  1094. //拿到页码按钮集合
  1095. li = document.createElement('li');
  1096. li.setAttribute('style', '' +
  1097. 'float: left;' +
  1098. 'padding: 5px;' +
  1099. 'color: #273346;' +
  1100. 'font-size: 15px;' +
  1101. 'cursor: pointer;' +
  1102. '');
  1103. li.innerText = i;
  1104.  
  1105. //保证至少页码为8的时候才出现省略号
  1106. if(i > 6 && totalPage > 7){
  1107. li.innerText = '...';
  1108. ul.appendChild(li);
  1109. li = document.createElement('li');
  1110. li.setAttribute('style', '' +
  1111. 'float: left;' +
  1112. 'padding: 5px;' +
  1113. 'color: #273346;' +
  1114. 'font-size: 15px;' +
  1115. 'cursor: pointer;' +
  1116. '');
  1117. li.innerText = totalPage;
  1118. ul.appendChild(li);
  1119. li = document.createElement('li');
  1120. li.setAttribute('style', '' +
  1121. 'float: left;' +
  1122. 'padding: 5px;' +
  1123. 'color: #273346;' +
  1124. 'font-size: 15px;' +
  1125. 'cursor: pointer;' +
  1126. '');
  1127. li.innerText = '>';
  1128. ul.appendChild(li);
  1129. break;
  1130. }
  1131. ul.appendChild(li);
  1132. //到头了您
  1133. if (i === totalPage){
  1134. li = document.createElement('li');
  1135. li.setAttribute('style', '' +
  1136. 'float: left;' +
  1137. 'padding: 5px;' +
  1138. 'color: #273346;' +
  1139. 'font-size: 15px;' +
  1140. 'cursor: pointer;' +
  1141. '');
  1142. li.innerText = '>';
  1143. ul.appendChild(li);
  1144. }
  1145. }
  1146. }
  1147.  
  1148.  
  1149. function btnControl(totalPage, currentPage) {
  1150. //小于7 就直接全部排出来就ok 不用搞这些花里胡哨的
  1151. if (totalPage < 8)return;
  1152.  
  1153. let li,
  1154. before = currentPage - 2, //头
  1155. after = currentPage + 2, //尾巴
  1156. list = document.getElementsByTagName('li'), //数据列表
  1157. arr = Array.from(list).filter((i)=>{ //实际页码改变的按钮
  1158. var index = parseInt(i.innerText);
  1159. return (index !== 1 && index !== totalPage && index.toString() !== 'NaN');
  1160. }),
  1161. headFlag = list[2],
  1162. endFlag = list[list.length - 3];
  1163.  
  1164. //控制插入 '...'
  1165. // if (currentPage > 4 && headFlag.innerText !== '...'){
  1166. // li = document.createElement('li');
  1167. // li.setAttribute('style', '' +
  1168. // 'float: left;' +
  1169. // 'padding: 5px;' +
  1170. // 'color: #273346;' +
  1171. // 'font-size: 15px;' +
  1172. // 'cursor: pointer;' +
  1173. // '');
  1174. // li.innerText = '...';
  1175. // list[0].parentElement.insertBefore(li, headFlag);
  1176. // }
  1177. // if ((currentPage > 1) && endFlag.innerText !== '...'){
  1178. // li = document.createElement('li');
  1179. // li.setAttribute('style', '' +
  1180. // 'float: left;' +
  1181. // 'padding: 5px;' +
  1182. // 'color: #273346;' +
  1183. // 'font-size: 15px;' +
  1184. // 'cursor: pointer;' +
  1185. // '');
  1186. // li.innerText = '...';
  1187. // list[0].parentElement.insertBefore(li, list[list.length - 2]); //加入之前的所以是 list.length-2
  1188. // }
  1189.  
  1190. //控制删除 '...'
  1191. if (currentPage < 5 && headFlag.innerText === '...'){
  1192. headFlag.parentNode.removeChild(headFlag);
  1193. }
  1194. if (after + 1 >= totalPage && endFlag.innerText === '...'){
  1195. endFlag.parentNode.removeChild(endFlag);
  1196. }
  1197.  
  1198.  
  1199. //关键的控制 基于他们展示时当前页 和 头尾 在边界位置以及普通位置的情况来做考虑
  1200. //在中间的时候 以currentPage为中心 前后2格
  1201. if (before > 1 && after < totalPage){
  1202. for (let i = currentPage - 2, j = 0; i <= currentPage + 2; i++, j++){
  1203. arr[j].innerText = i;
  1204. }
  1205. }
  1206.  
  1207. //头碰到边界了 说明要从2开始 这个currentPage是3了
  1208. if (before === 1){
  1209. for (let i = currentPage - 1, j = 0; i <= currentPage + 3; i++, j++){
  1210. arr[j].innerText = i;
  1211. }
  1212. }
  1213.  
  1214. //尾巴碰到边界了 说明要从currentPage回头数三个开始,不然会生成一个和totalPage相同的page,就是bug了。
  1215. if (after === totalPage){
  1216. for (let i = currentPage - 3, j = 0; i < currentPage + 2; i++, j++){
  1217. arr[j].innerText = i;
  1218. }
  1219. }
  1220.  
  1221. //当前页首尾~同上
  1222. if (currentPage === 1){
  1223. for (let i = currentPage + 1, j = 0; i <= arr.length + 1; i++, j++){
  1224. arr[j].innerText = i;
  1225. }
  1226.  
  1227. }
  1228. if (currentPage === totalPage){
  1229. for (let i = currentPage - arr.length, j = 0; i < totalPage; i++, j++){
  1230. arr[j].innerText = i;
  1231. }
  1232. }
  1233. }
  1234.  
  1235. window.setTimeout(function(){
  1236.  
  1237. var eleli = document.getElementsByTagName('li');
  1238. //console.log(eleli)
  1239. if(eleli) {
  1240. Object.values(eleli).forEach(function (value, index) {//数组
  1241. value.addEventListener('mouseover', () => {
  1242. value.style.border = '1px solid #d1d1d1';
  1243. value.style.padding = '4px';
  1244. });
  1245. value.addEventListener('mouseout', () => {
  1246. value.style.border = '0px solid #d1d1d1';
  1247. value.style.padding = '5px';
  1248. });
  1249. // console.log(value.className)
  1250. if(value.className == 'active') {
  1251. value.style.background = '#CCE8FF';
  1252. }
  1253. });
  1254. }
  1255. }, 100);
  1256. function arrowControl(target, totalPage){
  1257. let event = target || window.event;
  1258. if (event) {
  1259. target = event.target;
  1260. }
  1261.  
  1262. if (target) {
  1263. switch (target.innerText){
  1264. case '<': currentPage = currentPage === 1? 1 : currentPage - 1;break;
  1265. case '>': currentPage = currentPage === totalPage? totalPage : currentPage + 1; break;
  1266. case '...': break;
  1267. default: currentPage = parseInt(target.innerText);
  1268. }
  1269. }
  1270. }
  1271.  
  1272. function displayData() {
  1273. let arr = getRenderList(), p;//最后得到的数据
  1274. div.innerHTML = ''; //重置div内容区域
  1275. arr.forEach(i =>{
  1276. //p = document.createElement('p');
  1277. var div1 = document.createElement('div');
  1278. var linkimg1 = document.createElement('a');
  1279. var img1 = document.createElement('img');
  1280. var s1 = document.createElement('div');
  1281. var s2 = document.createElement('div');
  1282. var t1 = document.createElement('span');
  1283. var t2 = document.createElement('span');
  1284. var delfanhao = document.createElement('div');
  1285. div1.style.border = '3px solid #fff';
  1286. linkimg1.href = i.url;
  1287. linkimg1.onclick = function(){
  1288. GM_openInTab(i.url, {
  1289. active: false
  1290. });
  1291. return false;
  1292. }
  1293. img1.src = i.cover;
  1294. img1.style.width = '215px';
  1295. s1.innerText = i.fanhao;
  1296. t1.innerText = i.date;
  1297. t1.style.fontSize = '10px';
  1298. t2.innerText = i.adddate;
  1299. t2.style.fontSize = '10px';
  1300. t2.style.marginLeft = '60px';
  1301.  
  1302. delfanhao.innerHTML = '删除';
  1303. delfanhao.title = '删除';
  1304. delfanhao.className = '删除';
  1305. delfanhao.style.cursor = "pointer";
  1306. delfanhao.style.fontSize = '13px';
  1307. delfanhao.style.textAlign = 'center';
  1308.  
  1309.  
  1310. delfanhao.addEventListener('click', () => {
  1311. var ele = GM_getValue(listname);
  1312. delfanhao.parentNode.remove();
  1313. var result1 = confirm("是否确认删除清单 " + listname);
  1314. if (result1) {
  1315. Object.values(ele).forEach(function (value, index) {
  1316. if(i.fanhao == value.fanhao) {
  1317. ele.splice(index, 1)
  1318. GM_setValue(listname, ele);
  1319. showclipboard('移除清单 ' + listname, 0);
  1320.  
  1321. }
  1322. });
  1323. }
  1324. });
  1325. delfanhao.addEventListener('mouseover', () => {
  1326. delfanhao.style.color = 'red';
  1327. });
  1328. delfanhao.addEventListener('mouseout', () => {
  1329. delfanhao.style.color = 'black';
  1330. });
  1331.  
  1332. linkimg1.appendChild(img1);
  1333. div1.appendChild(linkimg1);
  1334. div1.appendChild(s1);
  1335. s2.appendChild(t1);
  1336. s2.appendChild(t2);
  1337. div1.appendChild(s2);
  1338. div1.appendChild(delfanhao);
  1339. div.appendChild(div1);
  1340. }); //展示一下
  1341. }
  1342.  
  1343. //这个是事件的监听函数
  1344. function pagination(target){
  1345. let totalPage = getTotalPage(data, pageCount);
  1346. //兼容拿到事件
  1347. arrowControl(target, totalPage);
  1348. btnControl(totalPage, parseInt(currentPage));
  1349. isActive();
  1350. displayData();
  1351. }
  1352.  
  1353. //首次注册生成第一页数据和分页栏
  1354. function firstInit() {
  1355. createBtn(parseInt(getTotalPage(data, pageCount)));
  1356. isActive();
  1357. displayData();
  1358. }
  1359. //window.onload = function () {
  1360. firstInit();
  1361. Array.from(document.getElementsByTagName('li')).forEach(i => i.onclick = function (e) {
  1362. pagination(e)
  1363. });
  1364. //}
  1365. }
  1366.  
  1367.  
  1368.  
  1369. paginationByJS(data, div, currentPage, pageCount, list, li);
  1370. }
  1371.  
  1372. })();