undefined是否会变为null原理解析

 更新时间:2023年02月10日 08:45:13   作者:我的div丢了肿么办  
这篇文章主要为大家介绍了undefined是否会变为null原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

echarts 会将 series data中的数据并不是你想的那样简单

我们很多小伙伴都使用过echarts。

然后 series:[{  data:[]  }] 中的数据可能并没有我们想的那样简单

为什么会这样说:因为你看下面这个例子绝对会然你有所收获。

series data 中的数据会自动发生变化吗?

<template>
  <div>
    <!-- 第1处:小伙伴们觉得这里数组中的值是否是
      [undefined, undefined, undefined, undefined,
      undefined, undefined, undefined]
    -->
    <h4>{{ objInfo.data1 }}</h4>
    <div id='demo1'></div>
  </div>
</template>
<script>
import echarts from 'echarts'
export default {
  data() {
    return {
      objInfo: {
        data1: [undefined, undefined, undefined, undefined,
        undefined, undefined, undefined],
        xdata1: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
      }
    }
  },
  mounted() {
    var myChart1 = echarts.init(document.getElementById("demo1"));
    let option1 = {
      xAxis: {
        type: 'category',
        data: this.objInfo.xdata1
      },
      yAxis: {
        type: 'value'
      },
      series: [
        {
          data: this.objInfo.data,
          type: 'line',
          smooth: true
        }
      ]
    };
    //第2处:小伙伴们觉得这里应该输出的数组的值是什么呢?
    console.log('控制台输入的数据', this.objInfo.data1)
    myChart1.setOption(option1); 
  }
}
</script>

大家觉得页面中

第1处: <h4>{{ objInfo.data1 }}</h4> 数组中的值是否是 undefined ?

很多小伙伴都会觉得这里应该是 

[undefined, undefined, undefined, undefined,
undefined, undefined, undefined] 是这样还是不是这样 ?

第2处:小伙伴们觉得这里应该输出的数组的值是什么呢?

console.log('控制台输入的数据', this.objInfo.data1)
[undefined, undefined, undefined, undefined, 
undefined, undefined, undefined] 是这样还是不是这样 ?

小伙伴们想好结果了吗? 如果想好了。请看下面的图片

为什么会series data 中 undefined 会变为 null

有的小伙伴会说:是不是echarts底层在更改了数据?
有可能,我们使用watch去监听一下,如果更改数据肯定会被我们监听到
watch: {
  "obj.data1": function (newval, oldval) {
    console.log('oldval', oldval)
    console.log('newval', newval)
  },
  deep: true,
},

通过上面的图片我们可以知道,echarts并没有更改数据.否者会触发watch

说明并不是echarts底层给我们改了数据。

那数据从undefined 变为 null 肯定是有一个地方改动了。

如果不是echarts,那就是vue。难道真的是vue给我们改了数据?

求证:undefined 会变为 null是 vue 的锅

<template>
  <div>
    <h3>数据会变为unll吗</h3>
    <h2>{{ data2 }}</h2>
   </div>
</template>
export default {
  data() {
    return {
      data2:[undefined,undefined]
    }
  },
  mounted() {
    console.log('data2', this.data2)
  }
}

我滴亲娘呢?真的是vue给我们改了的呀,简直不敢相信。

有的小伙伴又说:有没有可能也不是vue的锅。

而是js本身就有这样的特征,在视图上会由 undefined 变为 null

下面我们不要使用vue框架。就使用普通的js去看看。

如果还是从 undefined 变为了 null.说明是 vue 的锅。

否者这就是一个特征:在视图上会由 undefined 变为 null

小心求证 数据由 undefined 变为 null

<body>
    <h3>数据会发生变化吗?</h3>
    <div id="demo"> </div>
</body>
<script>
    let data = {
        arr: [undefined, undefined, undefined, undefined, '数据1'],
        title: '会发生变化吗?'
    }
    let demo = document.getElementById('demo')
    console.log('控制台的数据', data)
    let htmltest = `<div>${data.arr}</div>`
    demo.innerHTML = htmltest
</script>

我们发现了:

原生js中, undefined在视图上会变为空字符串。

但是在vue中,undefined在视图上会变为null。

我们看下:原生js中 null 在视图上是否也会变为空字符串吗?

<body>
    <h3>数据会发生变化吗?</h3>
    <div id="demo"> </div>
</body>
<script>
  let data = {
      arr: [undefined, '数据2', null, '数据4'],
  }
  let demo = document.getElementById('demo')
  console.log('控制台的数据', data)
  let htmltest = `<div>${data.arr}</div>`
  demo.innerHTML = htmltest
</script>

 原生js中 null 在视图上也会变为空字符串吗? 是的

我为什会纠结在视图上 undefined 发生了变化呢?

因为今天我发现:在页面上的null。

我在代码中找了好久都没有找到哪一个地方写了null.这让我很疑惑

花费了我不少时间,导致我没有办法摸鱼。

所以:为了更好的摸鱼,呸,呸,呸, 为了掘金的奖品 就写下了这篇文章。

总结

通过一步一步的分析:我们知道了

1==》在vue中, undefined 在视图上会变为 null。

在vue中, null 在视图上仍然是 null

补充:但是字符串 'undefined' 和 'null' 在视图上会保持不变

2==》原生js中, undefined 在视图上会变为空字符串。

null 在视图上也会变为空字符串。

补充:但是字符串 'undefined' 和 'null' 在视图上会保持不变

以上就是undefined是否会变为null原理解析的详细内容,更多关于undefined是否会变为null的资料请关注脚本之家其它相关文章!

相关文章

  • vue实现滚动鼠标滚轮切换页面

    vue实现滚动鼠标滚轮切换页面

    这篇文章主要为大家详细介绍了vue实现滚动鼠标滚轮切换页面,类似于纵向走马灯,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • vue环境如何实现div focus blur焦点事件

    vue环境如何实现div focus blur焦点事件

    这篇文章主要介绍了vue环境如何实现div focus blur焦点事件,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • vue使用swiper实现中间大两边小的轮播图效果

    vue使用swiper实现中间大两边小的轮播图效果

    这篇文章主要介绍了vue使用swiper实现中间大两边小的轮播图效果,本文分步骤通过实例代码讲解的非常详细,需要的朋友可以参考下
    2019-11-11
  • vue项目如何去掉URL中#符号的方法

    vue项目如何去掉URL中#符号的方法

    在开发过程中发现路径中带有/#/的标示,而且还去不掉,很丑陋,下面这篇文章主要给大家介绍了vue项目如何去掉URL中#符号的相关资料,文中通过实例代码的非常详细,需要的朋友可以参考下
    2022-07-07
  • Vue使用font-face自定义字体的案例详解

    Vue使用font-face自定义字体的案例详解

    @font-face 是 CSS 中的一个规则,它允许你加载服务器上的字体文件(远程或者本地),并在网页中使用这些字体,本文给大家介绍了Vue使用font-face自定义字体的案例,并通过代码讲解的非常详细,需要的朋友可以参考下
    2024-03-03
  • 基于Vue-Cli 打包自动生成/抽离相关配置文件的实现方法

    基于Vue-Cli 打包自动生成/抽离相关配置文件的实现方法

    基于Vue-cli 项目产品部署,涉及到的交互的地址等配置信息,每次都要重新打包才能生效,极大的降低了效率。这篇文章主要介绍了基于Vue-Cli 打包自动生成/抽离相关配置文件 ,需要的朋友可以参考下
    2018-12-12
  • vue-star评星组件开发实例

    vue-star评星组件开发实例

    下面小编就为大家分享一篇vue-star评星组件开发实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • Vue实现纵向的物流时间轴效果的示例代码

    Vue实现纵向的物流时间轴效果的示例代码

    在当今数字化的时代,用户体验的优化至关重要,物流信息的展示作为电商和供应链领域中的关键环节,其呈现方式直接影响着用户对货物运输状态的感知和满意度,所以本文介绍了Vue实现纵向的物流时间轴效果的方法,需要的朋友可以参考下
    2024-08-08
  • Pinia简单使用以及数据持久化详解

    Pinia简单使用以及数据持久化详解

    最近正在使用Pinia进行状态管理,我希望在重新刷新页面时保持状态,下面这篇文章主要给大家介绍了关于Pinia简单使用以及数据持久化的相关资料,需要的朋友可以参考下
    2022-05-05
  • vue实现移动端touch拖拽排序

    vue实现移动端touch拖拽排序

    这篇文章主要为大家详细介绍了vue实现移动端touch拖拽排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07

最新评论