当前位置: 首页 > wzjs >正文

阿里云要求的网站建设方案晋江网站开发

阿里云要求的网站建设方案,晋江网站开发,乐清新闻,wordpress销售由于图片和格式解析问题,可前往 阅读原文 Chrome DevTools 是开发者用于调试 Web 应用程序、分析性能、检查元素和网络请求的重要工具。无论是前端开发人员还是后端工程师,熟练掌握 Chrome DevTools 都能显著提高开发效率和调试精度。通过 DevTools&…

由于图片和格式解析问题,可前往 阅读原文

Chrome DevTools 是开发者用于调试 Web 应用程序、分析性能、检查元素和网络请求的重要工具。无论是前端开发人员还是后端工程师,熟练掌握 Chrome DevTools 都能显著提高开发效率和调试精度。通过 DevTools,我们可以快速识别并解决性能瓶颈、修复 bug、优化用户体验

Chrome DevTools 提供了多种强大的功能,包括但不限于:元素检查、网络调试、JavaScript 调试、性能分析、内存泄漏检测、日志查看等。通过这些功能,开发者可以实时查看页面结构、调试脚本、分析请求响应、监控应用状态,甚至在浏览器端进行模拟测试

:::warning 注意
本文只从JavaScript断点角度进行调试,其他方面如请求、性能、内存会以新的文章方式分享
:::

断点技巧

Chrome DevTools 提供了强大的断点调试功能,帮助开发者逐步执行代码,检查变量、查看调用堆栈,并实时观察代码的执行情况。以下是一些常用的 Chrome DevTools 断点调试技巧,帮助你更高效地定位问题

基本断点

通常开发时大家都喜欢console.log打印东西来看一些预期结果,你也可以通过在需要console的地方加上debugger来断住js,当执行到这里时,不仅可以看到你想要的信息,还可以看到当前作用域、变量、调用栈等一些信息,这样看起来更直观也更方便

// 假如有下面一段代码
button.addEventListener('click', clickCB);
function clickCB(e) {debugger;console.log(e);
}

22.png
23.png

条件断点

同样这里也是先在源码中指定位置debugger,或者如果你的源码并没有采取打包,源码好找的情况下可以直接在浏览器中找到对应的js文件直接打个条件注释断点就行

// 假如有下面一段代码 (当x<=0,断住)
const add = (x, y) => {x = 2 * x;return x + y;
}

24.png

25.png

27.png

DOM断点

28.png

DOM断点只能在浏览器中调试,有三种:

  • subtree modifications
  • attribute modifications
  • node removal

以上三种断点,也可用MutationObserverAPI来代替,方便配置使用灵活,官方文档

// 假如下面一段代码,当点击不同的按钮对ul进行增删改查,修改自身属性
<div class="domDebugger"><button>增加节点</button><button>删除节点</button><button>删除自己</button><button>更新子节点</button><button>更新子节点属性</button><button>更新当前元素属性</button>
</div>
<ul class="list"><li>1</li><li>2</li>
</ul><script>const dbtns = document.querySelectorAll('.domDebugger button');const list = document.querySelector('.list');dbtns[0].addEventListener('click', () => {const li = document.createElement('li');li.innerText = '新增的节点';list.appendChild(li);});dbtns[1].addEventListener('click', () => {list.removeChild(list.lastElementChild);});dbtns[2].addEventListener('click', () => {list.remove();});dbtns[3].addEventListener('click', () => {const li = document.createElement('li');li.innerText = '更新的节点';list.replaceChild(li, list.lastElementChild);});dbtns[4].addEventListener('click', () => {list.lastElementChild.setAttribute('class', 'li-class');});dbtns[5].addEventListener('click', () => {list.setAttribute('class', 'newclass');});
</script>
  • subtree modifications

节点监听:
29.png

当监听子节点变化时,只有当子节点(node)发生变化时,才会监听的到,如:子节点替换子节点删除子节点增加子节点的字节点变化(像:文本节点、注释节点、元素节点等等都会监听的到),但是节点的属性发生变化不会监听到

30.png

当点击上面的删除节点时就会被监听到,如上图;而当点击更新子节点属性或者当前元素属性时反而监听不到的

  • attribute modifications

属性监听:

31.png

监听当前元素属性发生变化时,而子节点属性变化监听不到;(想监听子节点的属性变化或者或者节点变化可以用开头提到的MutatorObserverAPI)

当点击更新当前元素属性时如下图所示,点击更新子节点属性不会监听到

32.png

  • node removal

34.png
这个只监听当前元素被删除,子几点的改变不会监听到,比较单一

当点击删除自己就会监听到

33.png

除了单独监听外,还可以同时监听三种类型,只要勾选上就行;除了这种调试,也可以通过前面提到的MutatorObserverAPI来调试

URL断点

添加对XHR的请求url的断点,当浏览器发起http请求时,如果断点的url包含请求url,就会打住断点

// 假如下面代码,点击按钮发起请求
const fetchApi = async () => {try {const rs = await fetch("http://localhost:3001/xxxx")const data = await rs.json()console.log(data)} catch(err) {console.log(err)}
}
const btn = document.querySelector('#btn');
btn.addEventListener('click', fetchApi)// ===== 服务代码 =====
app.use((req, res, next) => {res.header('Access-Control-Allow-Origin', '*');res.json({code: 200,message: 'Hello World',})
})
app.listen(port, () => {console.log(`Server is running on port ${port}`);
})

以上请求http://localhost:3001服务,现在我们在浏览器中添加对应的断点

35.png

36.png

事件监听断点

监听对应的事件当触发时就会打住断点,如:点击、鼠标、键盘事件等等

// 假如给一个元素绑定click、mouseover事件
// <div id="box" />
const target = document.querySelector("#box")
target.addEventListener("click", () => console.log('click...'))
target.addEventListener("mouseover", () => console.log('mouseover...'))

在浏览器上打上对应的断点

37.png

38.png

39.png

异常断点

异常断点可以在vscode中设置,如果抛出异常就会打住断点
添加vscode调试配置:

{"name": "Debugger Exception","request": "launch","type": "chrome","url": "http://localhost:5500","webRoot": "${workspaceFolder}/trandition"
}

在程序中直接抛出错误:

throw new Error('This is a test error');

40.png

调试React

React项目,用react-create-app启动项目,然后添加.vscode配置,点击debugger,在vscode中打个断点,就可以在vscode中调试代码了

{"name": "React","request": "launch","type": "chrome","url": "http://localhost:3000","webRoot": "${workspaceFolder}"
}

当点击对应的程序后打住断点:

20.png

调试Vue

目前用vite或者webpack生成的vue项目目前这样的都可以这样调试,以前的wepack要用sourcemap进行映射

{"name": "VueCli","request": "launch","type": "chrome","url": "http://localhost:8080","webRoot": "${workspaceFolder}",// 映射sourcemap"sourceMapPathOverrides": {// "webpack://?:*/*": "${workspaceFolder}/*"}
}

和React一样运行到对应的代码后打住断点

21.png

Override调试

可能有一种调试需要在线上环境下直接调试代码,对于简单的调试直接使用debugger即可,有时候需要改代码啥的,可能直接用debugger可能会变得有点麻烦,要是可以将线上运行的代码代理到本地,就可以在本地调试代码了,Chrome Override DevTools就是干这个的

此方式不能代理XHR请求

首先打开Source面板,选择Overrides,然后点击Select Folder for overrides按钮,会打开本地文件系统让你选择一个文件夹,用来保存后面调试的代码(这里最好新建一个空文件夹)

41.png
42.png

选择完后Chrome会提示访问权限,点击允许,此时network面板会出现一个黄色三角形,则证明Override第一步成功了

43.png

现在比如我们想调试一个index.js文件,点击netword面板,右击想要调试的文件,选择Save for overrides,此时当前文件就会被保存到目标文件夹里了

44.png
45.png

现在可以用编辑器打开目标文件夹,进行修改,修改会同步保存到浏览器,而且刷新浏览器也同样会被代理到本地文件夹哦,如下:文件开头添加debugger

46.png

最后

Chrome Devtools的强大之处仍不止这些,敬请关注后面的文章

由于图片和格式解析问题,可前往 阅读原文


文章转载自:

http://g2OhqbGz.qmpbs.cn
http://f3lhPcPB.qmpbs.cn
http://mpi2MyOf.qmpbs.cn
http://xYlr1omD.qmpbs.cn
http://6e3RfQAq.qmpbs.cn
http://bryH7hs8.qmpbs.cn
http://ZAZ4Sm3g.qmpbs.cn
http://kw4npL9Y.qmpbs.cn
http://5tHeer8z.qmpbs.cn
http://6hY97geO.qmpbs.cn
http://9O0B8DO3.qmpbs.cn
http://sREdl6zY.qmpbs.cn
http://vWCRGL92.qmpbs.cn
http://HUpGxDvD.qmpbs.cn
http://o5nE3lrg.qmpbs.cn
http://GYWN5UGr.qmpbs.cn
http://L8NucsKf.qmpbs.cn
http://un7LYGQT.qmpbs.cn
http://4l4wu7qY.qmpbs.cn
http://qc3v6GJE.qmpbs.cn
http://AbqRvgqx.qmpbs.cn
http://GiNQKWay.qmpbs.cn
http://DCwEyhIK.qmpbs.cn
http://FlbpCgXo.qmpbs.cn
http://YAedrufi.qmpbs.cn
http://Pzuarf4g.qmpbs.cn
http://TA9HHFhV.qmpbs.cn
http://L8rmGVG3.qmpbs.cn
http://UiwhDisJ.qmpbs.cn
http://AEutfFz7.qmpbs.cn
http://www.dtcms.com/wzjs/625788.html

相关文章:

  • 建筑公司财务做账流程电商网站如何做seo
  • 网站模板建站教程最成功的网络营销案例
  • 网站建设服务合同书泰州网站关键词优化
  • 网站建设新零售安全教育平台登录入口 登录
  • 网站建设行业网站漯河网站建设茂睿科技
  • 吴江区城乡建设局网站大美工设计网站官网
  • 建设网站的公司哪家好5118网站查询
  • 网站建设的心得网站 提交入口
  • 抚顺 网站建设网站标题上的小图标怎么做
  • 长葛哪里有做网站的建设网站的条件
  • 个人网站有什么内容运维工程师累吗
  • 网站维护有文化建设费网站原型的交互怎么做
  • 宁波网站建站公司无锡电子商务网站建设公司
  • 用什么软件制作网站智慧旅游网站建设
  • 漯河住房建设局网站seo优化工具软件
  • 网页设计代码网站怎么利用互联网推广
  • 做网站推广怎么说广告词五矿瑞和上海建设有限公司网站
  • 邯郸教育网站建设广西响应式网页建设找哪家
  • 用html做简单网站上海建筑设计院排名
  • 网站建设方案编写人网站正在备案中模板
  • 衡水建设企业网站公司网站创建
  • 北京专业制作网站公司哪家好广告文案经典范例200字
  • 盐城网站开发公司电话标书制作教学
  • 大学生做网站类型南通网站快照优化公司
  • 青岛做网站企业虚拟主机WordPress建站
  • 如何做kindle电子书下载网站电子商务seo招聘
  • 网站建设学什么的网站企业快速备案流程
  • 微信嵌入网站开发哪里的郑州网站建设
  • 网站域名 设置海南的网站建设公司
  • 宣传网站制作方案wordpress出境游