开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 233|回复: 3
收起左侧

[完成] js的命令大全有吗?F12调试命令

 关闭 [复制链接]
结帖率:97% (126/130)
发表于 2024-12-26 18:05:18 | 显示全部楼层 |阅读模式   安徽省阜阳市
10精币
网页有shadow 用不了填表
只能用js的命令

但是就记得个click()和Inner
有人能提供下吗
判断网页加载完毕等这样的命令

最佳答案

查看完整内容

// 等待页面加载完成后执行操作 await waitForPageLoad(); simulateInput('#username', 'test'); // 等待特定元素出现后操作 await waitForElement('#loginButton'); simulateClick('#loginButton'); // 等待多个元素都出现 await waitForElements(['#username', '#password', '#loginButton']); // 等待页面变化完成后操作 await waitForPageStable(); simulateInput('#searchBox', 'query'); // 等待网络请求完成 await wai ...
结帖率:100% (11/11)

签到天数: 19 天

发表于 2024-12-26 18:05:19 | 显示全部楼层   四川省资阳市

// 等待页面加载完成后执行操作
await waitForPageLoad();
simulateInput('#username', 'test');

// 等待特定元素出现后操作
await waitForElement('#loginButton');
simulateClick('#loginButton');

// 等待多个元素都出现
await waitForElements(['#username', '#password', '#loginButton']);

// 等待页面变化完成后操作
await waitForPageStable();
simulateInput('#searchBox', 'query');

// 等待网络请求完成
await waitForNetworkIdle();
console.log('所有请求已完成');

// 检查元素状态
if (isElementVisible('#submitButton') && isElementInteractive('#submitButton')) {
    simulateClick('#submitButton');
}

// 组合使用示例
async function login(username, password) {
    await waitForPageLoad();
    await waitForElement('#loginForm');

    simulateInput('#username', username);
    simulateInput('#password', password);

    await waitForPageStable();
    simulateClick('#loginButton');

    await waitForNetworkIdle();
    console.log('登录流程完成');
}


[JavaScript] 纯文本查看 复制代码
// 基础输入框操作
function simulateInput(selector, value) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    let reactInstance = null;
    for (const key in element) {
        if (key.startsWith('__reactProps$')) {
            reactInstance = element[key];
            break;
        }
    }

    if (reactInstance && reactInstance.onChange) {
        reactInstance.onChange({
            target: {
                value: value
            }
        });
        return true;
    }

    // 如果不是 React 元素,使用原生方式
    element.value = value;
    element.dispatchEvent(new Event('input', { bubbles: true }));
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 模拟点击操作
function simulateClick(selector) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }
    
    element.click();
    return true;
}

// 复选框操作
function simulateCheckbox(selector, checked) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    element.checked = checked;
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 下拉框选择
function simulateSelect(selector, value) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    element.value = value;
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 单选框操作
function simulateRadio(name, value) {
    const elements = document.querySelectorAll(`input[name="${name}"]`);
    if (!elements.length) {
        console.error('未找到单选框组:', name);
        return false;
    }

    for (const element of elements) {
        if (element.value === value) {
            element.checked = true;
            element.dispatchEvent(new Event('change', { bubbles: true }));
            return true;
        }
    }
    
    console.error('未找到对应值的单选框:', value);
    return false;
}

// 文本区域操作
function simulateTextarea(selector, value) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    element.value = value;
    element.dispatchEvent(new Event('input', { bubbles: true }));
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 表单提交
function simulateSubmit(formSelector) {
    const form = document.querySelector(formSelector);
    if (!form) {
        console.error('表单未找到:', formSelector);
        return false;
    }

    form.submit();
    return true;
}

// 清除表单
function clearForm(formSelector) {
    const form = document.querySelector(formSelector);
    if (!form) {
        console.error('表单未找到:', formSelector);
        return false;
    }

    form.reset();
    return true;
}

// 等待页面加载完成
function waitForPageLoad() {
    return new Promise((resolve) => {
        if (document.readyState === 'complete') {
            resolve();
        } else {
            window.addEventListener('load', resolve);
        }
    });
}

// 等待特定元素出现
function waitForElement(selector, timeout = 10000) {
    return new Promise((resolve, reject) => {
        const element = document.querySelector(selector);
        if (element) {
            resolve(element);
            return;
        }

        const observer = new MutationObserver((mutations, obs) => {
            const element = document.querySelector(selector);
            if (element) {
                obs.disconnect();
                resolve(element);
            }
        });

        observer.observe(document.body, {
            childList: true,
            subtree: true
        });

        // 设置超时
        setTimeout(() => {
            observer.disconnect();
            reject(new Error(`等待元素超时: ${selector}`));
        }, timeout);
    });
}

// 等待多个元素都出现
function waitForElements(selectors, timeout = 10000) {
    return Promise.all(selectors.map(selector => waitForElement(selector, timeout)));
}

// 等待页面变化完成(适用于单页应用)
function waitForPageStable(timeout = 1000) {
    return new Promise((resolve) => {
        let timer;
        const observer = new MutationObserver(() => {
            if (timer) clearTimeout(timer);
            timer = setTimeout(() => {
                observer.disconnect();
                resolve();
            }, timeout);
        });

        observer.observe(document.body, {
            childList: true,
            subtree: true,
            attributes: true
        });
    });
}

// 等待网络请求完成
function waitForNetworkIdle(timeout = 1000) {
    return new Promise((resolve) => {
        let timer;
        let pendingRequests = 0;

        const originalFetch = window.fetch;
        const originalXHR = window.XMLHttpRequest.prototype.send;

        window.fetch = async function(...args) {
            pendingRequests++;
            try {
                const response = await originalFetch.apply(this, args);
                return response;
            } finally {
                pendingRequests--;
                checkRequests();
            }
        };

        window.XMLHttpRequest.prototype.send = function(...args) {
            pendingRequests++;
            this.addEventListener('loadend', () => {
                pendingRequests--;
                checkRequests();
            });
            return originalXHR.apply(this, args);
        };

        function checkRequests() {
            if (timer) clearTimeout(timer);
            if (pendingRequests === 0) {
                timer = setTimeout(() => {
                    resolve();
                }, timeout);
            }
        }

        checkRequests();
    });
}

// 检查页面是否处于加载状态
function isPageLoading() {
    return document.readyState !== 'complete';
}

// 检查元素是否可见
function isElementVisible(selector) {
    const element = document.querySelector(selector);
    if (!element) return false;
    
    const style = window.getComputedStyle(element);
    return style.display !== 'none' && 
           style.visibility !== 'hidden' && 
           style.opacity !== '0';
}

// 检查元素是否可交互
function isElementInteractive(selector) {
    const element = document.querySelector(selector);
    if (!element) return false;
    
    return !element.disabled && 
           !element.readonly && 
           isElementVisible(selector);
}

2cdbe4d7-010b-4e68-bd15-6ae9d7c19461.png

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (1/1)

签到天数: 19 天

发表于 2024-12-26 19:17:18 | 显示全部楼层   河南省郑州市
回复

使用道具 举报

结帖率:100% (11/11)

签到天数: 19 天

发表于 2024-12-27 00:32:20 | 显示全部楼层   四川省资阳市
// 填写输入框
simulateInput("#email", "test@example.com");

// 点击按钮
simulateClick("#submit-button");

// 选中复选框
simulateCheckbox("#terms", true);

// 选择下拉框选项
simulateSelect("#country", "CN");

// 选择单选框
simulateRadio("gender", "female");

// 填写文本区域
simulateTextarea("#message", "这是一段测试文本");

// 提交表单
simulateSubmit("#myForm");

// 清除表单
clearForm("#myForm");

[JavaScript] 纯文本查看 复制代码
// 基础输入框操作
function simulateInput(selector, value) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    let reactInstance = null;
    for (const key in element) {
        if (key.startsWith('__reactProps$')) {
            reactInstance = element[key];
            break;
        }
    }

    if (reactInstance && reactInstance.onChange) {
        reactInstance.onChange({
            target: {
                value: value
            }
        });
        return true;
    }

    // 如果不是 React 元素,使用原生方式
    element.value = value;
    element.dispatchEvent(new Event('input', { bubbles: true }));
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 模拟点击操作
function simulateClick(selector) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }
    
    element.click();
    return true;
}

// 复选框操作
function simulateCheckbox(selector, checked) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    element.checked = checked;
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 下拉框选择
function simulateSelect(selector, value) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    element.value = value;
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 单选框操作
function simulateRadio(name, value) {
    const elements = document.querySelectorAll(`input[name="${name}"]`);
    if (!elements.length) {
        console.error('未找到单选框组:', name);
        return false;
    }

    for (const element of elements) {
        if (element.value === value) {
            element.checked = true;
            element.dispatchEvent(new Event('change', { bubbles: true }));
            return true;
        }
    }
    
    console.error('未找到对应值的单选框:', value);
    return false;
}

// 文本区域操作
function simulateTextarea(selector, value) {
    const element = document.querySelector(selector);
    if (!element) {
        console.error('元素未找到:', selector);
        return false;
    }

    element.value = value;
    element.dispatchEvent(new Event('input', { bubbles: true }));
    element.dispatchEvent(new Event('change', { bubbles: true }));
    return true;
}

// 表单提交
function simulateSubmit(formSelector) {
    const form = document.querySelector(formSelector);
    if (!form) {
        console.error('表单未找到:', formSelector);
        return false;
    }

    form.submit();
    return true;
}

// 清除表单
function clearForm(formSelector) {
    const form = document.querySelector(formSelector);
    if (!form) {
        console.error('表单未找到:', formSelector);
        return false;
    }

    form.reset();
    return true;
}


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表