首页技术js基础类型,js八大数据类型

js基础类型,js八大数据类型

编程之家2026-06-11707次浏览

大家好,今天来为大家分享js基础类型的一些知识点,和js八大数据类型的问题解析,大家要是都明白,那么可以忽略,如果不太清楚的话可以看看本篇文章,相信很大概率可以解决您的问题,接下来我们就一起来看看吧!

js基础类型,js八大数据类型

JS的基本数据类型

JS中一共有六种基本数据类型,分别是Undefined、Null、Boolean、Number、String,还有在ES6中新增的Symbol和ES10中新增的BigInt类型。

1. Undefined:未定义型

一个变量声明了但是未赋值的情况下就是undefined;

2. Null:空型

一般用来清空变量,也起了占位作用

3. String:字符型

js基础类型,js八大数据类型

凡是被双引号或单引号包裹起来的都叫做字符型,字符串有length属性。

4. Number:数值型

包含整数和浮点数(浮点数数值必须包含一个小数点,且小数点后面至少有一位数字)两种值。

(1)NaN:非数字类型。

特点:①涉及到的任何关于NaN的操作,都会返回NaN

② NaN不等于自身。

js基础类型,js八大数据类型

(2)isNaN():用于检查其参数是不是数值,得到的结果是一个布尔值,不是数值返回true,是数值返回false。

5. Boolean:布尔型

只有true和false两个值。

6. Symbol代表创建后独一无二且不可变的数据类型,它的出现我认为主要是为了解决可能出现的全局变量冲突的问题。

7. BigInt是一种数字类型的数据,它可以表示任意精度格式的整数,使用BigInt可以安全地存储和操作大整数,即使这个数已经超出了Number能够表示的安全整数范围。

JS数据有哪些类型

通过上一节课,大家应该明白了JS其实和C语言,特别是VB很相似的,大家有没有增加点自信,任何语言都要学习数据类型,所以我们开始吧

在JavaScript中不区分“字符”和“字符串”,一视同仁。这个就和VB很相似。用Var来定义变量,这个变量可以是字符串、字符、数值变量等

单考虑数值变量,无需考虑整形、长整型、浮点型什么的,直接用

在面向对象的设计模式中,将数据和处理的方法捆绑在一起形成的整体,称为对象。它封装了数据和操作数据的方法,使用时要先创建这个对象,用new运算符来调用对象的构造函数。(不同语言创建方式不同)。其实很常见的,比如日期的调用(看下图)

全局对象是所有全局方法的拥有者,用来统一管理全局方法。该对象不能使用new运算符创建对象实例,所有方法直接调用即可。

大家很难理解,只要理解为在所有程序集外建立的对象,可以在任何程序集里面直接调用(本来就镶嵌好的),类似VB中global,类似易语言的模块调用

字符串对象,对象封装了与字符串有关的特性,主要用来处理字符串。通过String对象,可以对字符串进行剪切、合并、替换等等。可以调用该对象的构造函数创建一个实例,其实在定义一个字符串类型变量时就也创建了一个String对象实例。

类似易语言中的“文本_切割”啥的,但是记住JS中的数数是从0开始的

我们分析下,字符串所用的方法,substring、slice按位置取出中间的文本,bold()文本加粗,fontcolor("red")设置字体颜色为灰色,\为转义字符,

定义数组,这个应该都见过 var vv=new Array("1","2","3","4");严重警告,这里的Array的第一个字母是大写的,不然定义失败;

Js基础算法有哪些

这次给大家带来Js基础算法有哪些,使用Js基础算法的注意事项有哪些,下面就是实战案例,一起来看一下。

素数

Q:你将如何验证一个素数?

A:一个素数只能被它自己和1整除。所以,我将运行一个while循环并加1。(看代码示例,如果你无法理解,那这不是你的菜。先回去学习javaScript基础知识然后再回来吧。)

方法1

function isPrime(n){

var pisor= 2;

while(n> pisor){

if(n% pisor== 0){

return false;

}

else

pisor++;

}

return true;

}

isPrime(137);//= true

isPrime(237);//= falseQ:你能做得更好吗?

A:可以。除数一次增加1个。在3之后我可以增加2.如果一个数可以被任何偶数整除,它将被2整除。

补充:如果你不需要把除数增加到这个数。你可以更早停止。让我在下面的步骤中解释一下(如果需要可以多读几遍)

第一步,任何数字都不能被大于它的一半的数字整除。例如,13将永远不能被7,8,9整除??它甚至可以是偶数的一半。例如,16将被8整除,但永远不会被9,10,11,12??

结论:一个数字将永远不能被一个大于其一半数值的数字整除。所以,我们可以少循环50%。

第二步,现在,如果一个数字不能被3整除。(如果它可被3整除,那么它就不是质数)。然后,它不可以被大于其值1/3的任何数整除。例如,35不能被3整除。因此,它永远不会被大于35/3的数整除,永远不能被12, 13, 14整除?如果你取一个像36一样的偶数,它将永远不能被13, 14, 15整除。

结论:一个数字可以被其数值的三分之一整除。

第三步,例如,你有一个数字127。127不能被2整除,因此你最多应该检查63.5。其次,127不能被3整除。因此,您将检查到127/3大约42。它不能被5整除,除数应该小于127/5大约25,而不是7。那么,我们该在哪里停下来?

结论:除数将小于math.sqrt(N)

方法2

如果你不能理解也不用担心,别管它。如果那你不是一个研究人员就没关系。

function isPrime(n)

{

var pisor= 3,

limit= Math.sqrt(n);

//check simple cases

if(n== 2|| n== 3)

return true;

if(n% 2== 0)

return false;

while(pisor<= limit)

{

if(n% pisor== 0)

return false;

else

pisor+= 2;

}

return true;

}

isPrime(137);//= true

isPrime(237);//= false素数因子

Q:如何求出一个数的所有素数因子?

A:执行一个while循环。开始除以2,如果不能整除,记录这个除数,直到完成。

function primeFactors(n){

var factors= [],

pisor= 2;

while(n>2){

if(n% pisor== 0){

factors.push(pisor);

n= n/ pisor;

}

else{

pisor++;

}

}

return factors;

}

primeFactors(69);//= [3, 23]Q:运行时间复杂度是多少?你能做得更好吗?

A:O(n)。可以将除数从3开始,累加2。因为,如果一个数被任何偶数整除,它将被2整除。因此,你不需要除以偶数。此外,你不会有一个大于其价值一半的因素。如果你想让它变得复杂,那就用第一题的补充概念吧。

Fibonacci(斐波那契)

Q:如何获得第n个斐波纳契数字?

A:我创建一个数组并从迭代开始。

斐波那契系列是面向初学者的最受欢迎的面试问题之一。所以,你必须学习这一个。

方法1

function fibonacci(n){

var fibo= [0, 1];

if(n<= 2) return 1;

for(var i= 2; i<=n; i++){

fibo[i]= fibo[i-1]+fibo[i-2];

}

return fibo[n];

}

fibonacci(12);//= 144Q:运行时间复杂度是多少?

A: O(n);

Q:你能让它递归吗?

方法2

function fibonacci(n){

if(n<=1){

return n;

} else{

return fibonacci(n-1)+ fibonacci(n-2);

}

}

fibonacci(12);//= 144Q:运行时间复杂度是多少?

A: O(2n);关于时间复杂度的细节

最大公约数

Q:你会如何找到两个数字的最大公约数?

function greatestCommonpisor(a, b){

var pisor= 2,

greatestpisor= 1;

//if u pass a-ve number this will not work. fix it dude!!

if(a< 2|| b< 2)

return 1;

while(a>= pisor&& b>= pisor){

if(a%pisor== 0&& b% pisor==0){

greatestpisor= pisor;

}

pisor++;

}

return greatestpisor;

}

greatestCommonpisor(14, 21);// 7

greatestCommonpisor(69, 169);//= 1算法范式

很抱歉。我也无法解释它。因为我自己80%的情况下都不能理解它。我的算法分析教练告诉我这个,又从课堂笔记偷走(我是一个好学生,顺便说一句!)

function greatestCommonpisor(a, b){

if(b== 0)

return a;

else

return greatestCommonpisor(b, a%b);

}注意:用你的大脑来理解它。

去重

Q:你将如何从数组中删除重复的成员?

A:执行一个循环,并保存一个对象/关联数组。如果我第一次找到一个元素,我会设置它的值为真(这将告诉我元素添加一次)。如果我在对象中找到这个元素,我不会将它插入到返回数组中。

function removeDuplicate(arr){

var exists={},

outArr= [],

elm;

for(var i=0; i<arr.length; i++){

elm= arr[i];

if(!exists[elm]){

outArr.push(elm);

exists[elm]= true;

}

}

return outArr;

}

removeDuplicate([1,3,3,3,1,5,6,7,8,1]);//= [1, 3, 5, 6, 7, 8]合并两个排序的数组

Q:怎样合并两个已排序数组?

A:我将为每个数组保留一个指针(看代码,并注意这个)。

function mergeSortedArray(a, b){

var merged= [],

aElm= a[0],

bElm= b[0],

i= 1,

j= 1;

if(a.length==0)

return b;

if(b.length==0)

return a;

/*

if aElm or bElm exists we will insert to merged array

(will go inside while loop)

to insert: aElm exists and bElm doesn't exists

or both exists and aElm< bElm

this is the critical part of the example

*/

while(aElm|| bElm){

if((aElm&&!bElm)|| aElm< bElm){

merged.push(aElm);

aElm= a[i++];

}

else{

merged.push(bElm);

bElm= b[j++];

}

}

return merged;

}

mergeSortedArray([2,5,6,9], [1,2,3,29]);//= [1, 2, 2, 3, 5, 6, 9, 29]不通过临时变量交换两个数的值

Q:如何在不使用临时变量的情况下交换两个数字?

function swapNumb(a, b){

console.log('before swap:','a:', a,'b:', b);

b= b-a;

a= a+ b;

b= a-b;

console.log('after swap:','a:', a,'b:', b);

}

swapNumb(2, 3);

//= before swap: a: 2 b: 3

//= after swap: a: 3 b: 2位操作:对不起,我无法向你解释这一点。 Kinjal Dave建议到 logical conjunction理解它。将浪费您30分钟。

function swapNumb(a, b){

console.log("a:"+ a+" and b:"+ b);

a= a ^ b;

b= a ^ b;

a= a ^ b;

console.log("a:"+ a+" and b:"+ b);

}

swapNumb(2, 3);

//= a: 2 and b: 3

//= a: 3 and b: 2字符串反向

Q:如何在JavaScript中反转字符串?

A:可以遍历字符串并将字母连接到新字符串。

方法1

function reverse(str){

var rtnStr='';

for(var i= str.length-1; i>=0;i--){

rtnStr+=str[i];

}

return rtnStr;

}

reverse('you are a nice dude');

//="edud ecin a era uoy"Q:你知道在现代浏览器中串联效果很好,但在像IE8这样的旧浏览器中会变慢。还有什么不同的方法,可以扭转一个字符串?

A:当然.我可以使用数组,也可以添加一些检查。如果字符串是NULL或其他字符串,这将失败。让我也做一些类型检查。使用此数组类似于在某些服务器端语言中使用字符串缓冲区。

方法2

function reverse(str){

var rtnStr= [];

if(!str|| typeof str!='string'|| str.length< 2) return str;

for(var i= str.length-1; i>=0;i--){

rtnStr.push(str[i]);

}

return rtnStr.join('');

}Q:运行时间复杂度是多少?

A: O(n);

Q:可以做得更好?

A:我可以遍历索引的一半,它会节省一点点。(这是没用的,可能不会打动面试官)

方法3

function reverse(str){

str= str.split('');

var len= str.length,

halfIndex= Math.floor(len/ 2)- 1,

revStr;

for(var i= 0; i<= halfIndex; i++){

revStr= str[len- i- 1];

str[len- i- 1]= str[i];

str[i]= revStr;

}

return str.join('');

}Q:这有效,但你可以做递归的方式吗?

A:可以。

方法4

function reverse(str){

if(str===""){

return"";

} else{

return reverse(str.substr(1))+ str.charAt(0);

}

}方法5

Q:你可以在方法中使用任何构建,使它更清洁吗?

function reverse(str){

if(!str|| str.length<2) return str;

return str.split('').reverse().join('');

}方法6

Q:你可以做反向函数作为字符串扩展吗?

A:我需要将这个函数添加到String.prototype,而不是使用str作为参数,我需要使用this

String.prototype.reverse= function(){

if(!this|| this.length<2) return this;

return this.split('').reverse().join('');

}

'abc'.reverse();

//='cba'单词反转

Q:你如何在句子中颠倒单词?

A:您必须检查整个字符串的空白区域。确定是否可能有多个空格。

//have a tailing white space

//fix this later

//now i m sleepy

function reverseWords(str){

var rev= [],

wordLen= 0;

for(var i= str.length-1; i>=0; i--){

if(str[i]==''|| i==0){

rev.push(str.substr(i,wordLen+1));

wordLen= 0;

}

else

wordLen++;

}

return rev.join('');

}内置方法的快速解决方案:

function reverseWords(str){

return str.split('').reverse();

}原位反转

Q:如果你有一个字符串如”I am the good boy”,怎样变为“I ma eht doog yob”?注意这些单词位置不变但是被反转了。

A:要做到这一点,我必须做字符串反向和字反转。

function reverseInPlace(str){

return str.split('').reverse().join('').split('').reverse().join('');

}

reverseInPlace('I am the good boy');//="I ma eht doog yob"Q: ok。好的,你能不使用内置反向函数做到吗?

A:(内心独白)有没有搞错!!

//sum two methods.

//you can simply split words by''

//and for each words, call reverse function

//put reverse in a separate function

//if u cant do this,

//have a glass of water, and sleep第一个非重复字符

Q:怎么在字符串中找到第一个非重复字符?

A:有什么条件吗?

A:比如是否区分大小写?

面试官可能会说No。

A:是长字符串还是短字符串?

Q:这些有什么关系吗?

A:例如,如果它是一个非常长的字符串,说一百万个字符,我想检查是否有26个英文字符正在重复。我可能会检查是否所有字符都在每200个字母中重复(例如),而不是循环遍历整个字符串。这将节省计算时间。

Q:简单起见,这个字符串是“the quick brown fox jumps then quickly blow air”。

function firstNonRepeatChar(str){

var len= str.length,

char,

charCount={};

for(var i=0; i<len; i++){

char= str[i];

if(charCount[char]){

charCount[char]++;

}

else

charCount[char]= 1;

}

for(var j in charCount){

if(charCount[j]==1)

return j;

}

}

firstNonRepeatChar('the quick brown fox jumps then quickly blow air');//="f"这有一个问题,不能再循环中及时退出。

删除重复的字符

Q:怎样删除字符串中的重复字符?

A:这与第一个非重复字符非常相似。你应该问一些类似的问题。它是区分大小写的吗?。

如果面试官说,这是区分大小写的,那么你就很轻松了。如果他说不。你可以使用string.toLowercase()来把字符串。面试官可能不喜欢这个方法。因为返回字符串不会拥有相同的大小写。所以

function removeDuplicateChar(str){

var len= str.length,

char,

charCount={},

newStr= [];

for(var i=0; i<len; i++){

char= str[i];

if(charCount[char]){

charCount[char]++;

}

else

charCount[char]= 1;

}

for(var j in charCount){

if(charCount[j]==1)

newStr.push(j);

}

return newStr.join('');

}

removeDuplicateChar('Learn more javascript dude');//="Lnmojvsciptu"回文检查

Q:如何检查一个字符串是否是回文?

A:把字符串反转,如果反转前后相等,那么它就是回文。

function isPalindrome(str){

var i, len= str.length;

for(i=0; i<len/2; i++){

if(str[i]!== str[len-1-i])

return false;

}

return true;

}

isPalindrome('madam')

//= true

isPalindrome('toyota')

//= false或者

function checkPalindrom(str){

return str== str.split('').reverse().join('');

}类似的:在 O(n)时间复杂度内判断一个字符串是否包含在回文字符串内。你能在O(1)时间解决问题吗?

找缺失的数字

Q:在一个1到100的未排序数组中找到缺失的数,你怎么做?

说明:数组中的数字为1到100。数组中只有一个数字缺

文章到此结束,如果本次分享的js基础类型和js八大数据类型的问题解决了您的问题,那么我们由衷的感到高兴!

asp语言教程(asp最新版本)lol卡拉曼达(lol卡拉曼达整体实力)