JavaScript演示类型数据
此JS代码是根据JS高级编程,正则表达式写成数据类型。
有数值转换 Number(),转换任意数据类型,parseInt()、parseFloat():专门用于把字符串转换成数值,转换字符串方法.Date类型,RegExp类型,返回函数等等。
应用介绍
//数据类型
console.log("111"); //111
var message= "some string";
var message1;
console.log(typeof message);//string
console.log(typeof 95+','+typeof null+","+typeof message1); //number,object,undefined
console.log(undefined == null); //true
console.log(undefined === null); //false
console.log(true == 1); //true
console.log(true === 1); //false
console.log(false == 0); //true
console.log(false === 0);//false
console.log(null == ""); //false
console.log(undefined == ""); //false
var message="false";
var messageAsBoolean=Boolean(message);
var mes;
var mesAsBoolean=Boolean(mes);
console.log(messageAsBoolean); //true 非空字符串 非零数字 任何对象
console.log(mesAsBoolean); //false 空字符串 0和NaN null undefined
console.log(Number.MIN_VALUE); //最小值 5e-324
console.log(Number.MAX_VALUE); //最大值 1.7976931348623157e+308
console.log(NaN == NaN); //false NaN与任何值都不相等
console.log(isNaN(NaN)); //判断是否是NaN
console.log(isNaN("blue")); //true 不能转换成数值
console.log(isNaN("10")); //false 可以被转换成数值10
//同样适用于对象,首先自动调用对象的valueOf()方法,
//然后确定是否能转换为数值,如果不能,则再调用toString()方法再测试返回值
var numTest={num:10,unNum:"blue"};
console.log(isNaN(numTest.num)); //false
console.log(isNaN(numTest.unNum)); //true
//数值转换 Number():转换任意数据类型,parseInt()、parseFloat():专门用于把字符串转换成数值
console.log(Number("Hello World")+","+Number("")+","+Number("000011")+","+Number(true)+","+Number(false));//NaN,0,11,1,0
console.log(parseInt("1234blue")+","+parseInt("")+","+parseInt("0xA")+","+parseInt(22.5)+","+parseInt("070")+","+parseInt("0xf"));//1234,NaN,10,22,70,15
//String
console.log("letter sigma:\u03a3.");
//toString()
var age =11;
var ageAsString=age.toString();
console.log(ageAsString + ","+ typeof ageAsString);//"11",string
var found = true;
var foundAsString=found.toString();
console.log(foundAsString + ","+ typeof ageAsString)//"true",string
//String()
var value4;
console.log(String(10)+","+String(true)+","+String(null)+","+String(value4));//10,true,null,undefined
//操作符
//NOT
var num1=25; //00000000000000000000000000011001
var num2=~num1; //0000000000000000000000000000110 (反码)
console.log(num2); //-26
console.log(num2 + 1);//-25 负数等于本身的反码+1
//AND
var num3=25; //00000000000000000000000000011001
var num4=3; //00000000000000000000000000000011
console.log(num3 & num4); //1 00000000000000000000000000000001 两个都是1时返回1
//OR
console.log(num3 | num4);//27 00000000000000000000000000011011 有一个1时返回1
//XOR
console.log(num3 ^ num4);//26 00000000000000000000000000011010 只有一个1的时候才返回1
//左移
var oldValue=2; //00000000000000000000000000000010
console.log(oldValue << 5);//00000000000000000000000001000000 左移5位得64 *左移不会影响符号位
//右移
var oldValue=64; //00000000000000000000000001000000
console.log(oldValue >> 5) //00000000000000000000000000000010 右移5位得2
//无符号右移
console.log(oldValue >>> 5);//00000000000000000000000000000010 右移5位得2
var oldValue=-64;//11111111111111111111111111000000
console.log(oldValue >>> 5);//00000111111111111111111111111110 右移5位用0代替得134217726.符号变化
//匿名参数
function sayHi(){
console.log(arguments[0]);//[0,"dhska",10]
console.log(arguments[1]);//"haha"
console.log(arguments.length);//2
}
sayHi([0,"dhska",10],"haha");
//没有重载,会被最后一个函数覆盖,只能通过arguments判断参数的数目和类型然后模拟重载
function chongzai(test1){
console.log(test1);
}
function chongzai(test1,test2){
console.log(test1);
console.log(test2);
}
chongzai(1,2); //1;2;
chongzai(2);//1;undefined
function chongzai(){
if(arguments.length==1){
console.log(arguments[0]);
}else if(arguments.length == 2){
console.log(arguments[0]);
console.log(arguments[1]);
}else{
return false;
}
}
chongzai(1,2); //1;2;
chongzai(1); //1;
chongzai(1,1,1) //false;
//检测引用类型instanceof(检测基本类型用typeof)
var colors=['black','white','bule'];
console.log(colors instanceof Array);//true 引用类型都是Object实例,基本类型都不是对象
//基本数据类型:Undefined、Null、Boolean、Number和String
//引用类型:Object、Array、Date、RegExp、Function
//Object
function displayInfo(args){
var output='';
if(typeof args.name == 'string'){
output+='Name: '+args.name + '\n';
}
if(typeof args.age == 'number'){
output +='Age: '+args.age+'\n';
}
console.log(output);
}
displayInfo({
name:'Nicholas',
age:29
});
displayInfo({
name:'Greg'
});
var person={name:'Nicholas',age:23}
var propertyName="name";
console.log(person.name);
console.log(person[propertyName]);//可以通过变量来访问
//Array
//检测数组
var colors=['black','blue','white'];
console.log(colors instanceof Array);//多个框架全局会存在问题
console.log(Array.isArray(colors));//最终确定到底是不是数组,不管是在哪个全局环境中创建的
//转换字符串方法
console.log(colors.toString());//"black,blue,white"
console.log(colors.toLocaleString());//"black,blue,white"
console.log(colors.valueOf());//["black", "blue", "white"]
console.log(colors);//["black", "blue", "white"]
//join()接收用作分隔符的字符串,然后返回包含所有数组项的字符串
console.log(colors.join(","));//black,blue,white
console.log(colors.join("||"));//black||blue||white
var person1={
toLocaleString:function(){
return "Nicholas";
},
toString:function(){
return "Nicholas";
}
}
var person2={
toLocaleString:function(){
return "Grigorios";
},
toString:function(){
return "Greg";
}
}
var people=[person1,person2];
console.log(people);
console.log(people.toString()); //Nicholas,Greg
console.log(people.toLocaleString()); //Nicholas,Grigorios
//栈方法
var count=colors.push("red","green");//推入两项
console.log(count);//5
console.log(colors);//["black", "blue", "white", "red", "green"]
var item=colors.pop(); //取得最后一项
console.log(item); //green
console.log(colors.length); //4
var count1=colors.push(colors);
console.log(count1);//5
console.log(colors);//["black", "blue", "white", "red", Array(5)]
var item1=colors.pop();
console.log(item1);//["black", "blue", "white", "red"]
//队列方法
console.log(colors);// ["black", "blue", "white", "red"]
var item=colors.shift();
console.log(item);//black
console.log(colors);//["blue", "white", "red"]
//模拟反向队列
var count=colors.unshift("grey","voilet");
console.log(count);//5
console.log(colors);//["grey", "voilet", "blue", "white", "red"]
//重排序方法
var values=[1,2,3,4,5];
values.reverse();
console.log(values);//[5, 4, 3, 2, 1]
values.push(10);
values.unshift(20);
console.log(values);//[20, 5, 4, 3, 2, 1, 10]
values.sort();
console.log(values);//[1, 10, 2, 20, 3, 4, 5] 只能按照最前面的一位排序
//自写比较函数传给sort(),也可以用于比较字符串
function compare(value1,value2){
// if(value1<value2){
// return -1;
// }else if(value1>value2){
// return 1;
// }else{
// return 0;
// }
return value1 - value2;
}
values.sort(compare);
console.log(values);//[1, 2, 3, 4, 5, 10, 20]
//操作方法
//concat(),先创建当前数组副本,然后将接收到的参数添加到这个副本末尾,最后返回新构建的数组
console.log(colors);//["grey", "voilet", "blue", "white", "red"]
var color2=colors.concat("yellow",["black","green"]);
console.log(colors);//["grey", "voilet", "blue", "white", "red"]
console.log(color2);//["grey", "voilet", "blue", "white", "red", "yellow", "black", "green"]
//slice(),基于当前数组中的一个或多个项创建一个新数组 ,参数传入起始位置
console.log(colors);//["grey", "voilet", "blue", "white", "red"]
var colors2=colors.slice(1);
var colors3=colors.slice(1, 4);
console.log(colors2);//["voilet", "blue", "white", "red"]
console.log(colors3);// ["voilet", "blue", "white"]
//splice() ,可用于删除(删除前两项splice(0,2))、插入(插入前两项splice(2,0,"red","green"))、替换(splice(2,1,"red","green"))
console.log(colors);// ["grey", "voilet", "blue", "white", "red"]
var removed=colors.splice(0,1);//删除第一项
console.log(removed);//["grey"]
console.log(colors);//["voilet", "blue", "white", "red"]
removed=colors.splice(1,0,"yellow","orange");//从位置1开始插入两项
console.log(removed);//[]
console.log(colors);//["voilet", "yellow", "orange", "blue", "white", "red"]
removed=colors.splice(1,1,"red","purple");//插入两项,删除一项(替换)
console.log(removed);//["yellow"]
console.log(colors);//["voilet", "red", "purple", "orange", "blue", "white", "red"]
//位置方法
var numbers=[1,2,3,4,5,4,3,2,1];
console.log(numbers.indexOf(4));//3
console.log(numbers.lastIndexOf(4));//5
console.log(numbers.indexOf(4,4));//5
console.log(numbers.lastIndexOf(4,4));//3
var person={name:"Nicholas"};
var people=[{name:"Nicholas"}];
var morePeople=[person];
console.log(people.indexOf(person));//-1
console.log(morePeople.indexOf(person));//0
//迭代方法
//every():对数组中的每一项运行给定函数,如果该函数对每一项都返回true,则返回true
console.log(numbers);//[1, 2, 3, 4, 5, 4, 3, 2, 1]
var everyResult=numbers.every(function(item,index,array){
return (item > 2);
})
console.log(everyResult);//false
//some():只要传入的函数对数组中的某一项返回true,就会返回true
var someResult=numbers.some(function(item,index,array){
return (item > 2);
})
console.log(someResult);//true
//filter():利用指定的函数确定是否在返回的数组中包含的某一项
var filterResult=numbers.filter(function(item,index,array){
return (item > 2);
});
console.log(filterResult);//[3, 4, 5, 4, 3]
//map():返回一个数组,数组的每一项都是在原始数组中的对应项上运行传入函数的结果
var mapResult=numbers.map(function(item,index,array){
return item * 2;
})
console.log(mapResult);//[2, 4, 6, 8, 10, 8, 6, 4, 2]
//forEach():对数组中的每一项运行传入的函数,无返回值
numbers.forEach(function(item,index,array){
//执行某些操作
})
//缩小方法 IE9+、Firefox 3+、Safari 4+ 、Opera 10.5 和Chrome
//reduce():从数组第一项开始,逐个遍历到最后
//reduceRight():从数组的最后一项开始,向前遍历到第一项
//接受两个参数:一个在每一项上调用的函数和(可选)作为缩小基础的初始值,传给
//reduce和reduceRight的函数接受4个参数:前一个值,当前值,项的索引和数组对象
//这个函数返回的任何值都会作为第一个参数自动传给下一项。第一次迭代发生在数组的第二项上
var values=[1,2,3,4,5];
var sum=values.reduce(function(prev,cur,index,array){
return prev+cur;
});
console.log(sum);//15
var sum=values.reduceRight(function(prev,cur,index,array){
return prev+cur;
});
console.log(sum);//15
//Date类型
var now=new Date();
console.log(now);//Tue Apr 17 2018 09:04:31 GMT+0800 (中国标准时间)
console.log(Date.parse(now));//1523927071000
var y2k=new Date(Date.UTC(2000,0));//GMT时间2000年1月1日午夜零时
console.log(y2k);//Sat Jan 01 2000 08:00:00 GMT+0800 (中国标准时间)
var arr2 = new Array(1,2,10,9,5,10,23,34,435,4534,12,
324,34,34,34,32,42,43,42,54,5,6,6767,4564,6546,4,
345,435,56,5653,5435,345,65,65,45,435,4);
//计算程序执行时间
function calculateTime(){
//取得开始时间
var start=Date.now();
console.log(start);
//调用函数
bubbleSort(arr2);
//取得停止时间
var stop=Date.now(),
result=stop-start;
console.log(stop);
console.log(result);
}
function bubbleSort(A){
var i,j,flag,temp;
for(i=A.length-1;i>=1;i--){
flag=0;
for(j=1;j<=i;j++){
if(A[j-1]>A[j]){
temp=A[j];
A[j]=A[j-1];
A[j-1]=temp;
flag=1;
}
}
if(flag==0)
return;
}
}
calculateTime();
var now=new Date();
console.log(now.toLocaleDateString());//2018/4/17
console.log(now.toLocaleTimeString());//上午9:27:30
//RegExp类型
var pattern1=/[bc]at/i;//匹配第一个"bat"或"cat",不区分大小写
var pattern2=new RegExp("[bc]at","i");//与pattern1相同,只不过是使用构造函数创建的
var re=null,i;
//只为/cat/创建了一个RegExp实例,第二次调用从索引为3的字符开始
for(i=0;i<10;i++){
re = /cat/g;
re.test("catastrophe");
}
//每一次都创建一个实例
for(i=0;i<10;i++){
re = new RegExp("cat","g");
re.test("catastrophe");
}
//exec():接受一个参数,即要应用模式的字符串,然后返回包含第一个匹配信息的数组
var text ="mom and dad and baby";
var pattern=/mom( and dad( and baby)?)?/gi;
var matches=pattern.exec(text);
console.log(matches.index);//0
console.log(matches.input);//mom and dad and baby
console.log(matches[0]);//mom and dad and baby
console.log(matches[1]);//and dad and baby
console.log(matches[2]);//and baby
//test():接受一个字符串参数,在模式与该传参数匹配的情况下返回true
var text="000-00-0000";
var pattern=/\d{3}-\d{2}-\d{4}/;
console.log(pattern.test(text));//true
//Function类型
function callSomeFunction(someFunction,someArgument){
return someFunction(someArgument);
}
function add10(num){
return num+10;
}
var result1=callSomeFunction(add10,10);
console.log(result1);//20
//返回函数
function createComparisonFunction(propertyName){
return function(object1,object2){
var value1=object1[propertyName];
var value2=object2[propertyName];
if(value1 < value2){
return -1;
} else if(value1 > value2){
return 1;
}else{
return 0;
}
};
}
var data=[{name:"Zachary",age:28},{name:"Nicholas",age:29}];
data.sort(createComparisonFunction("name"));
console.log(data[0].name);//Nicholas
data.sort(createComparisonFunction("age"));
console.log(data[0].name);//Zachary
function factorial(num){
if(num<=1){
return 1;
}else{
return num*factorial(num-1);
}
}
//修改解除factorial函数名耦合 用arguments.callee()
function factorial(num){
if(num <=1){
return 1;
}else{
return num*arguments.callee(num-1);
}
}
var trueFactorial=factorial;
factorial=function(){
return 0;
}
console.log(trueFactorial(5));//120
console.log(factorial(5));//0
//this
window.color="red";
var o={color:"blue"};
function sayColor(){
console.log(this.color);
}
sayColor();//red
o.sayColor=sayColor;
o.sayColor();//blue
//apply():接受两个参数:一个是在其中运行函数的作用域,
//另一个是参数数组,第二个参数可以是Array的实例,也可以是arguments对象
function sum10(num1,num2){
return num1+num2;
}
function callSum1(num1,num2){
return sum10.apply(this,arguments);//传入arguments对象
}
function callSum2(num1,num2){
return sum10.apply(this,[num1,num2]);//传入数组
}
console.log(callSum1(10,20));//30
console.log(callSum2(10,20));//30
//call():与apply方法作用相同,区别在于接收参数方式不同,在使用call时,
//传递函数的参数必须逐个列举出来
function callSum(num1,num2){
return sum10.call(this,num1,num2);
}
console.log(callSum(10,20));
//扩充函数赖以运行的作用域
sayColor.call(this);//red
sayColor.call(window);//red
sayColor.call(o);//blue
//bind():创建一个函数的实例,其this值会被绑定到传给bind()函数的值
var objectSayColor=sayColor.bind(o);
objectSayColor();//blue
此项目是根据<JS高级编程>、<正则表达式>写的练习演示。
©版权声明:本文内容由互联网用户自发贡献,版权归原创作者所有,本站不拥有所有权,也不承担相关法律责任。如果您发现本站中有涉嫌抄袭的内容,欢迎发送邮件至: [email protected] 进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。
转载请注明出处: apollocode » JavaScript演示类型数据
文件列表(部分)
名称 | 大小 | 修改日期 |
---|---|---|
10.html | 0.68 KB | 2020-01-24 |
15.html | 0.63 KB | 2020-01-24 |
20.html | 0.58 KB | 2020-01-24 |
22.html | 0.58 KB | 2020-01-24 |
index.html | 0.58 KB | 2020-01-24 |
js | 0.00 KB | 2020-02-40 |
1-5.js | 15.12 KB | 2020-01-24 |
10.js | 1.62 KB | 2020-01-24 |
14.js | 1.20 KB | 2020-01-24 |
15.js | 2.53 KB | 2020-01-24 |
20.js | 0.36 KB | 2020-01-24 |
22.js | 4.65 KB | 2020-01-24 |
6.js | 9.53 KB | 2020-01-24 |
7.js | 4.50 KB | 2020-01-24 |
8.js | 1.38 KB | 2020-01-24 |
9.js | 3.55 KB | 2020-01-24 |
areasCommon.js | 0.58 KB | 2020-01-24 |
cityJson.js | 181.85 KB | 2020-01-24 |
citySet.js | 5.08 KB | 2020-01-24 |
defineproperty.js | 2.18 KB | 2020-01-24 |
detectDom.js | 2.53 KB | 2020-01-24 |
es6.js | 18.05 KB | 2020-01-24 |
getRandomPic.js | 2.05 KB | 2020-01-24 |
jquery-1.11.3.min.js | 93.71 KB | 2020-01-24 |
Popt.js | 0.90 KB | 2020-01-24 |
province.js | 5.86 KB | 2020-01-24 |
regexp.js | 10.39 KB | 2020-01-24 |
sun.js | 38.04 KB | 2020-01-24 |
test.js | 0.78 KB | 2020-01-24 |
moveTest.html | 1.23 KB | 2020-01-24 |
province.html | 1.87 KB | 2020-01-24 |
regexp.html | 0.31 KB | 2020-01-24 |
发表评论 取消回复