前端自动脚本中常见的几个问题,你遇到了吗?

更新日期: 2022-05-24阅读: 650标签: 脚本

公司有个审核平台,下班时间没人审核,审核速度更是着急人,所以老板让我写一个能够自动审核的脚本,只用于下班时间。我就开始了自己的第一个自动脚本。

自动脚本没有想象中那么难,作为一个前端,我们依旧使用我们最擅长的 js 。写一段需要执行的 js 代码,然后放入到调试器中回车执行,此时我们的自动脚本就能正常跑起来喽!

示例:


没有写过自动脚本的前端,赶紧看过来!写自动脚本常见的几个问题分别如下:

问题1:获取到的元素是为 null ?

我们通常直接使用 document.getElementById('btn') 就可以稳定地获取到元素,但是我今天在别人的网站里,审查元素的时候,可以找到 id 为 btn 的元素,但是在调试器中获取到的一直是 null 。

现象:document.getElementById('pass-btn') 直接获取时,返回的是 null ,调试器中选中元素,然后再获取元素时,此时获取到的元素不为空。

原因:检查页面结构中是否包含 iframe 结构,如果元素是包含在 iframe 引入的外部文件中,就会出现上述问题。

解决办法:先找到 iframe ,在当前对象中查找 dom

var iframe = window.document.getElementById('myframe')
var test = iframe.contentWindow.document.getElementById('pass-btn')
console.log('-->', test)

contentWindow 是一个只读属性,返回指定 iframe 的窗口对象,各个浏览器均支持。

此时就能很稳定的查找到元素了,不需要其他任何操作。

问题2:使用 js 添加的点击事件无效?

js 中触发点击事件有两种方式:click 和 onclick 。

现象:自己在本地写的触发点击事件,使用的 onclick() 在本地示范的时候,可以触发,没有任何问题,如:

<a href="javascript:;" id="btn" onclick="alert('2')">
 确定
</a>

<script>
 var btn = document.getElementById('btn')
 btn.onclick() 
</script>

此时如果换成:

var btn = document.getElementById('btn')
 btn.addEventListener('click', () => {
 console.log('执行')
})
btn.onclick()

此时的点击事件就会失效,运行脚本的时候静静躺那不执行,我们来看看 click 与 onclick 的区别?

click 是一个方法, onclick 是一个事件。

方法是写语句直接调用,即显示调用,可以触发 onclick 事件,事件一般都以 on 开头,不需要程序调用,事件触发的函数会在相应的事件触发时调用。

所以写自动脚本时,使用 click 去调用,模拟用户的点击操作。

问题3:调试器中断点如何避开?

有经验的程序员会在项目重要的操作流程中加入 debugger 断点操作,在不打开调试器的时候能够正常运行,打开调试之后就会出现断点,阻止我们在调试器执行脚本。我们如何忽略断点呢?

现象:添加 debugger 后,打开调试模式,程序就会执行到断点时停住,代码无法继续向下执行!


解决办法:禁用所有断点,如图所示:


来自:https://www.cnblogs.com/web-learn/p/16304894.html


链接: https://www.fly63.com/article/detial/11576

javascript 3d 脚本库 - three.js的进行简要介绍

本文的目标是对three.js进行简要介绍。我们将从设置一个(案例)场景开始,使用一个旋转的立方体。在页面底部提供一个工作示例,以防您遇到困难,需要帮助。

mongodb shell 运行js脚本的四种方式

MongoDB 是一个基于分布式文件存储的数据库。是一个介于关系数据库和非关系数据库之间的产品。这篇文章讲解mongodb shell 运行js脚本的四种方式。

defer和async的区别

async 对于应用脚本的用处不大,因为它完全不考虑依赖(哪怕是最低级的顺序执行),不过它对于那些可以不依赖任何脚本或不被任何脚本依赖的脚本来说却是非常合适的,最典型的例子:Google Analytics

如何用网页脚本追踪用户

本文介绍如何编写 JavaScript 脚本,将用户数据发回服务器。数据发回服务器的常见做法是,将收集好的用户数据,放在unload事件里面,用 AJAX 请求发回服务器。

npm脚本执行多个任务

如果遇到一个类似的需求,比如执行npm publish命令前想先升级下项目的版本,基础操作是在shell中输入两次命令分别为npm run version和npm run publish,但是有没有更简单的方法呢?请看下面的内容:

8个实用Python的脚本,收藏备用

脚本写的好,下班下得早!程序员的日常工作除了编写程序代码,还不可避免地需要处理相关的测试和验证工作。例如,访问某个网站一直不通,需要确定此地址是否可访问,服务器返回什么,进而确定问题在于什么

两个实用的shell脚本实例

今天主要分享两个shell脚本实例,内容不重要,重点是看如何去实现。批量创建特殊要求用户,需求:批量创建10个系统帐号hwb01-hwb10并设置密码(密码为随机数,要求字符和数字等混合)。

如何将 FIBJS 脚本打包成 exe 可执行文件

本文将会介绍如何将 FIBJS 脚本打包成Windows 上的 exe 可执行文件。FIBJS 是一个主要为 Web 后端开发而设计的应用服务器开发框架,它建立在 Google v8 JavaScript 引擎基础上

Hershell:一款功能强大的跨平台反向Shell生成器

Hershell是一款功能强大的跨平台反向Shell生成器,该工具使用Go语言开发,基于TCP反向Shell实现其功能。该工具使用了TLS来保障数据通讯的安全性,并且提供了证书公共密钥指纹绑定功能来防止通信数据被拦截。

javascript中defer的作用是什么

defer是脚本程序强大功能中的一个“无名英雄”。它告诉浏览器Script段包含了无需立即执行的代码,并且,与SRC属性联合使用,它还可以使这些脚本在后台被下载,前台的内容则正常显示给用户。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!