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

学校网站建设学生文明上网哪里有免费的网站推广

学校网站建设学生文明上网,哪里有免费的网站推广,简述jsp网站开发的环境配置,ppt自动生成器由于图片和格式解析问题,可前往 阅读原文 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://www.dtcms.com/wzjs/235937.html

相关文章:

  • 网站如何推广搜索引擎seo优化怎么做
  • 网站开发终止协议书贵阳网站建设制作
  • wordpress led主题seo优化与推广招聘
  • 医院网站建设运营方案搜索引擎名词解释
  • 做毕设网站多少钱需要推广的app在哪里找
  • wordpress科技网站模板淘宝关键词怎么优化
  • 东昌网站建设浙江seo外包费用
  • 莱芜找工作网站bt蚂蚁磁力搜索天堂
  • 移动网站建设什么平台可以打广告做宣传
  • 个人网站开发平台有哪些企业网站的作用有哪些
  • 睡不着偷偷看b站今日热点新闻事件2022
  • 软文怎么优化网站上海培训机构排名榜
  • 免费建商城网站搜索引擎排名国内
  • 品牌网络营销公司北京搜索关键词优化
  • 国外哪些网站做产品推广比较好谷歌推广哪家公司好
  • 夏县做网站谷歌seo搜索
  • 四川城乡建设监管网站2024年的新闻
  • 衡水网站建设集团最佳磁力搜索天堂
  • 建筑工程有限责任公司网站关键词优化系统
  • 校园二手网站开发的意义宁德市疫情最新消息
  • 打开网站自动跳转代码bt磁力在线种子搜索神器下载
  • 天津市规划局官方网站建设项目郑州疫情最新情况
  • 韩国学校网站模板百度推广优化怎么做
  • 用手机可以做网站seo搜索引擎排名优化
  • 做网站 需要工信部备案吗百度竞价开户多少钱
  • 怎么找的做网站的人seo是什么岗位简称
  • 观澜网站建设seo教程排名第一
  • 舟山外贸建站公司seo知识培训
  • 网站建设地图怎么设置网站如何宣传推广
  • 武都区建设局网站成全视频免费观看在线看