web前端技术笔记(九)JavaScript介绍、变量、操作元素属性

JavaScript介绍

JavaScript是运行在浏览器端的脚步语言,JavaScript主要解决的是前端与用户交互的问题,包括使用交互与数据交互。 JavaScript是浏览器解释执行的,前端脚本语言还有JScript(微软,IE独有),ActionScript( Adobe公司,需要插件)等。

前端三大块
1、HTML:页面结构
2、CSS:页面表现:元素大小、颜色、位置、隐藏或显示、部分动画效果
3、JavaScript:页面行为:部分动画效果、页面与用户的交互、页面功能
#JavaScript嵌入页面的方式

1、行间事件(主要用于事件)

<input type="button" name="" onclick="alert('ok!');">

2、页面script标签嵌入

<script type="text/javascript">        
    alert('ok!');
</script>

3、外部引入

<script type="text/javascript" src="js/index.js"></script>
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>

	<!-- 第三种嵌入js的方式:外链js   -->
	<script type="text/javascript" src="js/hello.js"></script>
	
	<!-- 第二种嵌入js的方式:内嵌js   -->
	<script type="text/javascript">		
		alert("hello world too!");
	</script>

</head>
<body>

	<!-- 第一种嵌入js的方式:行间事件   -->
	<input type="button" name="" value="点击" onclick="alert('hello world!')">
</body>
</html>

变量

JavaScript 是一种弱类型语言,javascript的变量类型由它的值来决定。 定义变量需要用关键字 ‘var’

 var iNum = 123;
 var sTr = 'asd';

//同时定义多个变量可以用","隔开,公用一个‘var’关键字

 var iNum = 45,sTr='qwe',sCount='68';

变量类型

5种基本数据类型:
1、number 数字类型
2、string 字符串类型
3、boolean 布尔类型 true 或 false
4、undefined undefined类型,变量声明未初始化,它的值就是undefined
5、null null类型,表示空对象,如果定义的变量将来准备保存对象,可以将变量初始化为null,在页面上获取不到对象,返回的值就是null

1种复合类型:
object

javascript语句与注释

1、一条javascript语句应该以“;”结尾

<script type="text/javascript">    
var iNum = 123;
var sTr = 'abc123';
function fnAlert(){
    
    
    alert(sTr);
};
fnAlert();
</script>

2、javascript注释

<script type="text/javascript">    

// 单行注释
var iNum = 123;
/*  
    多行注释
    1、...
    2、...
*/
var sTr = 'abc123';
</script>

变量、函数、属性、函数参数命名规范

1、区分大小写
2、第一个字符必须是字母、下划线(_)或者美元符号($)
3、其他字符可以是字母、下划线、美元符或数字

匈牙利命名风格:

对象o Object 比如:oDiv
数组a Array 比如:aItems
字符串s String 比如:sUserName
整数i Integer 比如:iItemCount
布尔值b Boolean 比如:bIsComplete
浮点数f Float 比如:fPrice
函数fn Function 比如:fnHandler
正则表达式re RegExp 比如:reEmailCheck

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<script type="text/javascript">

		// 单行注释

		/*
			多行注释
			下面将两个变量申明合成一句
		*/
		
		//var iNum = 12;
		//var sTr = 'abc';


		var iNum = 12,sTr='abc';

		var iNum02;


		//alert(iNum);

		//alert(sTr);

		alert(iNum02);




	</script>
</head>
<body>
	
</body>
</html>

获取元素方法一

可以使用内置对象document上的getElementById方法来获取页面上设置了id属性的元素,获取到的是一个html对象,然后将它赋值给一个变量,比如:

<script type="text/javascript">
    var oDiv = document.getElementById('div1');
</script>
....
<div id="div1">这是一个div元素</div>

上面的语句,如果把javascript写在元素的上面,就会出错,因为页面上从上往下加载执行的,javascript去页面上获取元素div1的时候,元素div1还没有加载,解决方法有两种:

第一种方法:将javascript放到页面最下边

....
<div id="div1">这是一个div元素</div>
....

<script type="text/javascript">
    var oDiv = document.getElementById('div1');
</script>
</body>

第二种方法:将javascript语句放到window.onload触发的函数里面,获取元素的语句会在页面加载完后才执行,就不会出错了。

<script type="text/javascript">
    window.onload = function(){
      
      
        var oDiv = document.getElementById('div1');
    }
</script>

....

<div id="div1">这是一个div元素</div>
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>

	<script type="text/javascript">
		// 整个页面加载完后再加载花括号内得代码
		window.onload = function(){
      
      

			/*
			document.getElementById('div1').style.color = 'red';
			document.getElementById('div1').style.fontSize = '30px'
			
			用变量简化代码:

			*/
			// 通过id获取元素赋值给oDiv
			var oDiv = document.getElementById('div1');
			// 改变元素属性
			oDiv.style.color = 'red';
			oDiv.style.fontSize = '30px';

		}		


	</script>


</head>
<body>
	<div id="div1">这是一个div元素</div>



</body>
</html>

操作元素属性

获取的页面元素,就可以对页面元素的属性进行操作,属性的操作包括属性的读和写。

操作属性的方法
1、“.” 操作
2、“[ ]”操作

属性写法

1、html的属性和js里面属性写法一样
2、“class” 属性写成 “className”
3、“style” 属性里面的属性,有横杠的改成驼峰式,比如:“font-size”,改成”style.fontSize”

通过“.”操作属性:

<script type="text/javascript">

    window.onload = function(){
      
      
        var oInput = document.getElementById('input1');
        var oA = document.getElementById('link1');
        // 读取属性值
        var sValue = oInput.value;
        var sType = oInput.type;
        var sName = oInput.name;
        var sLinks = oA.href;
        // 写(设置)属性
        oA.style.color = 'red';
        oA.style.fontSize = sValue;
    }

</script>

......

<input type="text" name="setsize" id="input1" value="20px">
<a href="http://www.itcast.cn" id="link1">1122</a>
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<script type="text/javascript">
		
		window.onload = function(){
      
      
			var oDiv = document.getElementById('div1');
			var oA = document.getElementById('link');
			var oDiv2 = document.getElementById('div2');

			// 读取属性
			var sId = oDiv.id
			alert(sId);

			
			// 写属性
			oDiv.style.color = "red";
			oA.href = "http://www.baidu.com";
			oA.title = "这是去到百度网的链接";


			// 操作class属性需要写成 className
			oDiv2.className = "box2";
		}

	</script>

	<style type="text/css">
		
		.box{
      
      
			font-size:20px;
			color:gold;
		}

		.box2{
      
      
			font-size:30px;
			color:pink;
		}

	</style>
</head>
<body>
	<div id="div1">这是一个div元素</div>
	<a href="#" id="link">这个一个链接</a>

	<div class="box" id="div2">这是第二个div</div>
</body>
</html>

通过“[ ]”操作属性:

<script type="text/javascript">

    window.onload = function(){
      
      
        var oInput1 = document.getElementById('input1');
        var oInput2 = document.getElementById('input2');
        var oA = document.getElementById('link1');
        // 读取属性
        var sVal1 = oInput1.value;
        var sVal2 = oInput2.value;
        // 写(设置)属性
        // oA.style.val1 = val2; 没反应
        oA.style[sVal1] = sVal2;        
    }

</script>

......

<input type="text" name="setattr" id="input1" value="fontSize">
<input type="text" name="setnum" id="input2" value="30px">
<a href="http://www.itcast.cn" id="link1">传智播客</a>
<div id="div1">这是一个div元素</div>
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<script type="text/javascript">
		window.onload = function(){
      
      
			var oDiv = document.getElementById('div1');
			var sMystyle = 'fontSize';
			var sValue = '30px';
			/*	
				这一句没有作用:变量sMystyle被认为是一个属性
				oDiv.style.sMystyle = sValue;
			*/

			/* 
				属性用变量来代替的话需要用[]来操作

			 */
			oDiv.style[sMystyle] = sValue;
		}

	</script>
</head>
<body>
	<div id="div1">这是一个div元素</div>
</body>
</html>

innerHTML

innerHTML可以读取或者写入标签包裹的内容

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<script type="text/javascript">
		
		window.onload = function(){
      
      

			var oDiv = document.getElementById('div1');

			// 读取元素里面的内容
			var sTr = oDiv.innerHTML;
			alert(sTr);

			// 写元素里面的内容
			//oDiv.innerHTML = "修改的文字";
			oDiv.innerHTML = "<a href='http://www.itcast.cn'>传智播客</a>"

		}


	</script>
</head>
<body>
	<div id="div1">这是一个div元素</div>
</body>
</html>

猜你喜欢

转载自blog.csdn.net/qq_27251475/article/details/119966135