欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

小强的HTML5移动开发之路(28)—— JavaScript回顾3

程序员文章站 2022-05-03 21:14:51
一、基本数据类型 number:数字类型 string:字符串 (注意s小写:string是基本类型) boolean:布尔类型 //前三个都有对应的包装类 null:空类型 undefined:...

一、基本数据类型

number:数字类型

string:字符串 (注意s小写:string是基本类型)

boolean:布尔类型 //前三个都有对应的包装类

null:空类型

undefined:未定义类型

测试一:

	
	
		<script>
			function f1(){   //number类型
        /*有返回值时也不能function void f1(){}*/
				alert('hello');
	/*alert(); 弹出消息框*/
				alert('hehe');
				var i=100;
	//js当中字符串可用单引号也可用双引号
				i='hello';
        //typeof是一个运算符,可以返回变量实际存放的数据的类型
				alert(typeof i);
	/*js是弱类型语言 不能: number i=100; 不能在声明时指明其类型,在运行时才能确定*/
			}
			function f2(){   //string类型
				var str1='hello';
				var str2='hello';
				if(str1==str2){
					alert("str1==str2");
				}else{
					alert("str1!=str2");
				}
				var str3='100';
				var i=100;
				if(str3==i){ //两个=号,进行类型转换
					alert("str3==i");
				}else{
					alert("str3!=i");
				}
				if(str3===i){ //三个=号,不进行类型转换
					alert("str3==i");
				}else{
					alert("str3!=i");
				}
			}
			function f3(){  //boolean类型
				//布尔类型只有两个值:true/false;
				var flag=true;
				alert(typeof flag);
			  //var str="abc";
				var str=new object();//创建一个对象,对象会转换为true;
				var str=null; //转换为false;
				var str;  //undefined 转换为false;
				//强制转换,非空的字符串转换为true,非零的数字转换为true;
				if(str){
					alert('结果为真');
				}else{
					alert('结果为假');
				}
			}
			function f4(){  //null类型
				var obj=null;
			//null类型只有一个值——null;
			//输出的结果是object
				alert(typeof obj);
			}
			function f5(){ //undefined类型
				var obj;
				alert(typeof obj);
			}
		</script>	
	
	
		
	
测试二:parseint

	
	
		<script>
		/*number--->string
		  string---->number
		*/
			function f1(){  //字符串变数字
		//		var str1='fsfs';     读出nan
		//              var str1="1234fsfs";  可以读出1234
		//              var str1="fsfs1234";   不可以读出
		//              var str1="22323.08";
				var str1='1234';
		//window.parseint();  window可以省略
				var n1=parseint(str1);
//js浮点运算会有误差,先放大x倍,再缩小x倍
 		//		var n2=parsefloat(str1);
		//undefined + 数字 = nan
				alert(n1+100);
			}
			function f2(){
				var n1=100;
		//number--->number(对应的包装类型)  再调用tostring();
				var s1=n1.tostring();
			//      var s1=n1+'';
			}
		</script>
	
	
		
	
 
测试三:string的方法

length属性:返回字符串的长度

charat(index):返回指定位置的字符

substring(from,to):返回子字符串

indexof(str):返回字符串在原字符串中的位置

lastindexof(str):

match(regexp):返回符合正则表达式的一个数组

截取

	function f4(){ //string的方法
		var str1="abcdef";
		var str2=str1.substring(1,4);
		alert(str2);
	}
正则
	function f5(){
		var str="asdfas12323adfasf23423";
   //在js中用/reg/,在执行时,会将//内的内容转换成一个regexp对象
		var reg=/[0-9]+/g;  
   //reg中是一个对象,不是字符串,注意加一个g搜索整个字符串,还有i忽略大小写。
		var arr=str.match(reg);
		alert(arr);
	}
查找

	function f6(){
		var str1="sdf1223asdfasf23423";
		var reg=/[0-9]+/;
		//alert(typeof reg);
		alert(reg instanceof regexp);
		var index = str1.search(reg);
		alert(index);
	}
替换

	function f7(){
		var str1="sdf444asdfadf4423";
		var reg=/[0-9]+/g;
		var str2 = str1.replace(reg,'888');
		alert(str2);
	}

二、object类型(数组、函数,其他的在下一篇中)

1、数组

js数组的长度可变

js数组元素是任意的(可以混合存放不同类型的数据)

	
		<script>
			function f1(){  //创建数组的第一种方式
				var arr=new array();  //()可以省略不写
				arr[0]=1;
				arr[3]=2;
				arr[5]='abc';
				alert(arr.length);
				alert(arr[1]);
				alert(arr[3]);		
			}
			function f2(){ //第二种方式
				var arr=[];
				arr[0]=1;
				arr[3]=22;
				var arr=[1,2,3,4,5,6];
				arr[7]=11;
				alert(arr.length);
			}
			function f3(){ //多维数组的创建
				var arr = new array();
				arr[0]=[1,2,3,4,5];
				arr[1]=[6,7,8,9,10,11,12,13];
				arr[2]=[14,15,16,17,18,19];
				for(var i=0;i
	
		
	
数组中的一些函数
	
		<script>
			function f1(){
				var a1 = [1, 2, 3];
				var str = a1.join(|);
				alert(str);
			}
			function f2(){
				var a1 = [1, 2, 3];
				 var a2 = [4, 5, 6];
				 var a3 = a1.concat(a2); //数组连接
				 alert(a3);
			}
			function f4(){
				var a1 = [1, 2, 3];
				var a2 = a1.reverse(); //是对原有数组翻转
				alert(a2);
				alert(a1);  //原数组变了
			}
			function f5(){
				var a1 = [1, 2, 3, 4, 5, 6];
				var a2 = a1.slice(2,4); //对数组截取
				alert(a2);
				alert(a1); //原数组没有变化
			}
			function f6(){
				var a1 = [5, 1, 7, 2, 8];
				var a2 = a1.sort(); //从小到大
				alert(a2);
			}
			function f7(){
				var a1 = [15, 111, 7, 22, 88];
				var a2 = a1.sort(); //默认按照字典顺序排序
				alert(a2); 
			}
			function f8(){
				var a1 = [15, 111, 7, 22, 88];
				var a2 = a1.sort(function(t1, t2){
					return t2-t1;
				}); 
				alert(a2); 
			}
			function f9(){  //按照字符串长度排序
				var a1 = ['abc', 'bb', 'casd', 'a'];
				var a2 = a1.sort(function(t3, t4){
					return t4.length-t3.length;
				}); 
				alert(a2); 
			}
		</script>
	
	
		
	
 
2、函数

定义一个函数

function 函数名(参数){

函数体

}

要注意的几个问题

a.不能有返回类型的声明,但是可以有返回值。

b.函数其本质是一个对象,是function类型的实例,函数名是一个变量,存放了这个对象的地址(函数名是一个变量)

c.在函数内部,可以使用arguments对象访问参数

d.函数不能重载

	
	
		<script>
			function add(a1, a2){
				return a1+a2;
			}
			function test(){
				var sum = add(1, 1);
				alert(sum);
			}
			function test2(){
			//	alert(typeof add);
				alert(add instanceof function);  //函数是function类型的实例
				var f2 = add; 			//存放的是对象的地址
				add = null; 			 //add指向空
				var sum = f2(1, 1); 		//等价于 add(1, 1);
				alert(sum);
			}
			function add2(arg1, arg2){
				//return  arg1 + arg2;
				return arguments[0]+arguments[1];
			}
			function add3(arg1, arg2){  //首先指向一个对象
				return arg1+arg2+100;
			}
			function add3(){	//指向了另一个对象
				return arguments[0]+arguments[1];
			}
			function test3(){
				//var sum = add2(1);         //结果为nan,因为arg2是undifined
				//var sum(1, 1, 1);    //结果为2
				//var sum=add(1, 1);
				//var sum = add2(1, 1, 1);
				var sum = add3(1, 1);
				alert(sum);
			}
		</script>
	
	
		
	
其他object类型请看下一篇