web前端面试题附答案035-关于number考点大全,走过路过不会错过

1、如何创建一个number数值型的变量

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            // 创建一个16进制的数值
            var num3 = 0xFF;
            
</script>

2、不管是多少进制,整形,浮点型,十进制,还是十六进制,判断类型的结果都是一样的,结果都是number类型的

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            console.log(typeof(num2));
            // 创建一个16进制的数值
            var num3 = 0xFF;
            console.log(typeof(num3));
</script>

3、具体要判断类型的时候,他又是字符串的

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            console.log(typeof(num2));
            // 创建一个16进制的数值
            var num3 = 0xFF;
            var type1 = typeof(num3)
            if (type1 === 'number') {
                console.log('进来啦!!!');
            }
</script>

4、如何拿到真是的[object Number]类型呢?

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            console.log(typeof(num2));
            // 创建一个16进制的数值
            var num3 = 0xFF;
            var type1 = typeof(num3)
            console.log(Object.prototype.toString.call(num3));
</script>

5、还有什么办法判断是不是数值?

        通过isNaN()函数,如果不是数值型,就返回false

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            console.log(typeof(num2));
            // 创建一个16进制的数值
            var num3 = 0xFF;
            var type1 = typeof(num3)
            console.log(isNaN(num3));
</script>

6、instanceof咋用

number是一个基本类型,会被存储在栈内存里,用instanceof是监测不出来的,他更善于监测堆内存那边的东西

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            console.log(typeof(num2));
            // 创建一个16进制的数值
            var num3 = 0xFF;
            var num4 = new Number(100)
            // false
            console.log('-----', num3 instanceof Number)  
            // true
            console.log('=====', num4 instanceof Number)
</script>

7、有时候你发现服务端给你返回的id失真了?

        数值型的极限长度是17位,超过17位就会失真

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            // 创建一个16进制的数值
            var num3 = 0xFF;
            var num4 = new Number(100)

            // 失准或者失去精度或者不精确
            var num5 = 8888888888888888; // 16位
            var num6 = 88888888888888885; // 17位
            console.log('-------------', num5);
            console.log('=============', num6);
</script>

8、判断是否等于 == 和 ===

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            // 创建一个16进制的数值
            var num3 = 0xFF;
            var num4 = new Number(100)

            var string1 = '5';
            console.log(num == string1); // true
            console.log(num === string1); // false
</script>

10、隐式转换

<script>
            // 创建一个10进制number数值
            var num = 5;
            var num2 = 5.55;
            // 创建一个16进制的数值
            var num3 = 0xFF;
            var num4 = new Number(100)

            var string1 = '5';
            console.log(num + num2); // 10.55
            console.log(num + string1); // 55
            console.log(num + true); // 6
            console.log(num + false); // 5
            console.log(num + Object); // 5function Object() { [native code] }
            console.log(num + Boolean); // 5function Boolean() { [native code] }
            console.log(num + []); // 5
            console.log(num + {}); // 5[object Object]
            console.log(-num); // -5
            console.log(--num); // 4
            console.log(num++); // 4
            // Uncaught ReferenceError: undefied is not defined
            console.log(num + undefied); 
            console.log(num + null); // 5
 </script>

11、保留2位小数咋做的?

<script>
            var num1 = 99.234234;
            var num2 = 3;
            console.log(num1.toFixed(2)); // 99.23
            console.log(num2.toFixed(2)); // 3.00
</script>

12、setTimeout定时返回数字

     你以为返回Function吗?你可以在自己的vue组件中试着多走几次看看是个啥? 

<script>
            var num = 1;
            var myTimeout = null;
            function timeoutFn() {
                myTimeout = setTimeout(() => {
                    if (num > 10) {
                        window.clearTimeout(myTimeout);
                    } else {
                        console.log('----', myTimeout);
                        timeoutFn();
                        num++;
                    }
                }, 10)
            }
            timeoutFn();
</script>

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一些拼多多面试中可能会涉及到的前端面试题答案: 1. 说一下 CSS 盒模型? 答:CSS 盒模型是指在网页布局时,每个元素所占据的空间可以看做是一个矩形的盒子。盒模型包括内容区域(content)、内边距区域(padding)、边框区域(border)和外边距区域(margin)。 2. 什么是闭包? 答:闭包是指在函数内部定义的函数,它可以访问到它外部函数的变量和参数,即使外部函数已经执行完毕,闭包仍然可以访问到这些变量和参数。闭包在 JavaScript 中非常常见,比如在事件处理器、定时器、Ajax 请求等场景中都会用到。 3. 什么是跨域?如何解决跨域问题? 答:跨域是指在浏览器中,如果一个网页的脚本试图访问不同源(协议、域名、端口)的服务器资源,就会引发跨域问题。为了保证浏览器的安全性,浏览器会限制脚本访问不同源的资源。 解决跨域问题的方法有很多种,常用的方法包括: - JSONP:利用 <script> 标签可以跨域访问资源的特性,通过动态创建 <script> 标签,将需要获取的数据以参数的形式传递给服务器,服务器在返回时将数据包裹在一个函数调用中,从而实现跨域获取数据。 - CORS:CORS(Cross-Origin Resource Sharing)是一种基于 HTTP 头部的跨域解决方案,它允许服务器在响应头中设置 Access-Control-Allow-Origin 头部,表明哪些源可以访问该资源。 - 代理:通过在同源服务器上设置代理,在代理服务器上转发请求,从而实现跨域访问资源。 4. 如何实现一个简单的 Promise? 答: ```javascript function MyPromise(fn) { var self = this; self.value = null; self.error = null; self.onFulfilled = null; self.onRejected = null; function resolve(value) { setTimeout(function() { self.value = value; self.onFulfilled(self.value); }, 0); } function reject(error) { setTimeout(function() { self.error = error; self.onRejected(self.error); }, 0); } fn(resolve, reject); } MyPromise.prototype.then = function(onFulfilled, onRejected) { var self = this; self.onFulfilled = onFulfilled; self.onRejected = onRejected; }; ``` 5. 什么是事件冒泡和捕获?如何阻止事件冒泡? 答:事件冒泡和捕获是指在页面中,当一个元素触发了某个事件时,该事件会先从最外层的元素开始依次向下传递,直到触发该事件的元素为止,这个过程称为事件冒泡;相反,事件捕获是从最外层元素开始,依次向下寻找触发该事件的元素,这个过程称为事件捕获。 阻止事件冒泡的方法包括: - 使用 Event 对象的 stopPropagation() 方法,可以阻止事件继续向上传播。 - 在事件处理函数中,返回 false 可以阻止事件继续向上传播。 以上是一些常见的拼多多前端面试题答案,希望对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

经海路大白狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值