//实现与后台和流程图部分的交互 import {getElementXPaths, global, readXPath} from "./global.js"; var startMsg = { "type": 0, msg: ""}; chrome.runtime.sendMessage(startMsg, function(response) { console.log(response.msg); }); //每次打开新页面的时候需要告诉后台 chrome.runtime.onMessage.addListener( function(request, sender, sendResponse) { if (request["type"] == 1){ sendResponse("回答处理结果"); } } ); global.ws = new WebSocket("ws://localhost:8084"); global.ws.onopen = function() { // Web Socket 已连接上,使用 send() 方法发送数据 console.log("已连接"); let message = { type: 0, //消息类型,0代表连接操作 message: { id: global.id, //socket id title: document.title, //网页标题 } }; this.send(JSON.stringify(message)); }; export function input(value) { let message = { "type": "InputText", "history": history.length, //记录history的长度 "tabIndex": -1, "xpath": readXPath(global.nodeList[0]["node"], 0), "allXPaths": getElementXPaths(global.nodeList[0]["node"]), "value": value, }; let msg = { type: 3, msg: message }; window.stop(); chrome.runtime.sendMessage(msg); msg = { type: 2, value: value, xpath: message.xpath, id: global.id}; chrome.runtime.sendMessage(msg); } //点击元素操作 export function sendSingleClick() { let message = { "type": "singleClick", "history": history.length, //记录history的长度 "tabIndex": -1, "useLoop": false, //是否使用循环内元素 "xpath": readXPath(global.nodeList[0]["node"], 0), "allXPaths": getElementXPaths(global.nodeList[0]["node"]), }; let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } export function sendChangeOption(optionMode, optionValue){ let message = { "type": "changeOption", "optionMode": optionMode, "optionValue": optionValue, "history": history.length, //记录history的长度 "tabIndex": -1, "useLoop": false, //是否使用循环内元素 "xpath": readXPath(global.nodeList[0]["node"], 0), "allXPaths": getElementXPaths(global.nodeList[0]["node"]), }; let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } export function sendMouseMove(){ let message = { "type": "mouseMove", "history": history.length, //记录history的长度 "tabIndex": -1, "useLoop": false, //是否使用循环内元素 "xpath": readXPath(global.nodeList[0]["node"], 0), "allXPaths": getElementXPaths(global.nodeList[0]["node"]), }; let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } //采集单个元素 export function collectSingle() { let message = { "type": "singleCollect", "history": history.length, //记录history的长度 "tabIndex": -1, "parameters": global.outputParameters, }; let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } //采集无规律多元素 export function collectMultiNoPattern() { let message = { "type": "multiCollectNoPattern", "history": history.length, //记录history的长度 "tabIndex": -1, "parameters": global.outputParameters, }; let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } //采集有规律多元素 export function collectMultiWithPattern() { //先点击选择全部然后再 let message = { "type": "multiCollectWithPattern", "history": history.length, //记录history的长度 "tabIndex": -1, "loopType": 1, "xpath": "", //默认值设置为空 "allXPaths": "", "isDescendents": global.app._data.selectedDescendents, //标记是否采集的是子元素 "parameters": global.outputParameters, }; if (!detectAllSelected()) //如果不是全部选中的话 { message.loopType = 2; //固定元素列表 } if (message.loopType == 1) { message["xpath"] = global.app._data.nowPath; message["allXPaths"] = global.app._data.nowAllPaths; } else { //固定元素列表 message["pathList"] = []; for (let i = 0; i < global.nodeList.length; i++) { message["pathList"].push(readXPath(global.nodeList[i]["node"], 0)); } } let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } //循环点击单个元素 export function sendLoopClickSingle(name) { let message = { "type": "loopClickSingle", "history": history.length, //记录history的长度 "tabIndex": -1, "useLoop": true, //是否使用循环内元素 "xpath": readXPath(global.nodeList[0]["node"], 0), "allXPaths": getElementXPaths(global.nodeList[0]["node"]), "loopType": 0, //循环类型,0为单个元素 "nextPage": false, //是否循环点击下一页 }; if (name == "下一页元素") { message.nextPage = true; } let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } //循环点击每个元素 export function sendLoopClickEvery() { let message = { "type": "loopClickEvery", "history": history.length, //记录history的长度 "tabIndex": -1, "xpath": "", //默认值设置为空 "allXPaths": "", "useLoop": true, //是否使用循环内元素 "loopType": 1, //循环类型,1为不固定元素列表 }; if (!detectAllSelected()) //如果不是全部选中的话 { message.loopType = 2; //固定元素列表 } if (message.loopType == 1) { message["xpath"] = global.app._data.nowPath; } else { //固定元素列表 //有的网站像淘宝,每个元素都有一个独一无二的ID号,这时候就不适用用id进行xpath定位了,这个问题暂时搁置 message["pathList"] = []; for (let i = 0; i < global.nodeList.length; i++) { message["pathList"].push(readXPath(global.nodeList[i]["node"], 0)); } } let msg = { "type": 3, msg: message }; chrome.runtime.sendMessage(msg); } //检测是否xpath对应的元素被全选了,个数判断即可 export function detectAllSelected() { if (global.app._data.nowPath == "") { return false; } else { let num = 0; let result = document.evaluate(global.app._data.nowPath, document, null, XPathResult.ANY_TYPE, null); var node = result.iterateNext(); //枚举第一个元素 while (node) { // console.log(node.innerHTML); num++; node = result.iterateNext(); } if (num == global.nodeList.length) { return true; } else { return false; } } }