最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 调试React,console.log就是个弟弟

    正文概述 掘金(卡颂)   2020-11-24   824

    作为前端,console.log是我们日常调试最常用的方法。

    这个方法能在调试面板打印参数的值,方便我们快速调试局部代码。

    React中,我们经常用console.log打印state,来检查他有没有正确的被渲染。

    state只包含一两个值时,console.log还不错。但是当state包含越来越多属性(尤其是在ClassComponent),看起来就不太直观了。

    console.table

    console.table方法可以直观的将要打印的数据格式化为表格的形式展示。

    Chrome dev-tools中,效果如下:

    调试React,console.log就是个弟弟

    当传入的第一个参数为object类型,会被格式化为表格,其他类型效果与console.log一致。

    表格的第一列是索引标签,对于Array,为索引下标。对于Object,为对象的key

    同时,当点击列标题时,表格会以标题作为排序依据。

    比如,如下代码: 调试React,console.log就是个弟弟

    点击index列后:

    调试React,console.log就是个弟弟

    PS:在Firefox中,console.table当前显示行数限制在1000行

    console.table第二个参数为可选的“列”。默认情况下会显示所有列的数据。

    传入可选的“列”后可以只显示你关注的数据,在处理数据结构复杂的大对象时很有帮助。

    比如,对于代码:

    调试React,console.log就是个弟弟

    传入['c2']作为“列”参数:

    调试React,console.log就是个弟弟

    打印state

    回到React,我们通常将服务端返回的数据保存在state中。其中可能包括不需要在组件中使用的冗余数据。

    使用“列”参数可以只展示你需要关注的数据。

    看个例子

    在如下例子中,API返回了用户的JSON数据。他们将会被保存在state中。

    使用console.table打印:

    调试React,console.log就是个弟弟

    接下来如果我们想实现一个过滤“货币类型”为“人民币”的按钮。

    const onlyYuanUsers = users.filter( user => user.currency === "Yuan Renminbi")
    console.table(onlyYuanUsers)
    

    这会打印过滤后的数据。

    调试React,console.log就是个弟弟

    除了我们想检查的currency字段,其他字段会干扰我们检查结果的正确性。

    这里我们使用“列”参数:

    console.table(onlyYuanUsers, ['id', 'currency'])
    

    这下要检查结果的正确性就清晰明了了。

    调试React,console.log就是个弟弟

    兼容性

    所有现代浏览器都支持console.table

    调试React,console.log就是个弟弟

    IE不支持(毕竟我说的是现代浏览器)。[狗头]


    起源地下载网 » 调试React,console.log就是个弟弟

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元