JavaScript快速入門-實戰(例子)

一、模擬bootstrap中的模態框

效果圖:(點我後,彈出對話框,最下面的內容能夠看到,可是有必定的透明度。)html

思路分析:bootstrap

總體分爲三層,最底層(點我),中間透明層(實現透明效果),最頂層(最新內容展現)app

很明顯,三個div就能夠實現,正常狀況上面2層div隱藏起來,經過點擊「點我」後,上面2層div浮現出來,這樣就實現了動畫效果。dom

代碼以下:ide

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>小白教程</title>
</head>
<body>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
	body{
	   margin:0;
	}
        .back{
            background-color:yellow;
            height: 2000px;
        }

        .shade{
            position: fixed;
            top: 0;
            bottom: 0;
            left:0;
            right: 0;
            background-color: blue;
            opacity: 0.2;
        }

        .hide{
            display: none;
        }

        .models{
            position: fixed;
            top: 50%;
            left: 50%;
            margin-left: -100px;
            margin-top: -100px;
            height: 200px;
            width: 200px;
            background-color: red;

        }
	#ID1{
		margin-left:500px;
		margin-top:200px;
	}
	#ID2{
		float:right;
	}
    </style>
</head>
<body>
<div class="back">
    <input id="ID1" type="button" value="點我" onclick="action('show')">
</div>

<div class="shade hide"></div>
<div class="models hide">
    <input id="ID2" type="button" value="取消" onclick="action('hide')">
</div>

<script>

    function action(act){
		//獲取遮罩層節點、最外層節點
        var shadeNode=document.getElementsByClassName("shade")[0];
        var topNode=document.getElementsByClassName("models")[0];
		
		//點我後,若是參數爲show,則遮罩層和最外層展現出來;若是參數爲hide,則遮罩層和最外層隱藏起來。
        if(act=="show"){
              shadeNode.classList.remove("hide");
              topNode.classList.remove("hide");
        }else {
              shadeNode.classList.add("hide");
              topNode.classList.add("hide");
        }

    }
</script>
</body>
</html>

</body>

</html>

  

知識點分析:動畫

一、body設置margin爲0.保證html頁面置頂。ui

二、遮罩層和最外層的position爲fixed;this

三、遮罩層鋪滿屏幕,top、right、bottom、left都設爲0;spa

四、最外層位置居中,這個重點說一下:3d

通常狀況下,咱們設置最外層div的距離top爲50%,left爲50%。

可是,這個和咱們預想的有些差距,由於div自己有高度和寬度,因此看上去不是居中的位置,這時候咱們須要把div總體向上、向左移動50%(height和width)。

            top: 50%;
            left: 50%;
            margin-left: -100px;
            margin-top: -100px;
            height: 200px;
            width: 200px;                

  

二、全選、反選

實現效果:

代碼以下:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>小白教程</title>
<style>
 #selected{
	position:fixed;
	width:50%;
	height:50%;
	margin-left:300px;
	border:1px solid red;
 }

</style>
</head>
<body>
<div id='selected'>
	<button onclick="select('all');">全選</button>
     <button onclick="select('cancel');">取消</button>
     <button onclick="select('reverse');">反選</button>

     <table border="1" id="Table">
         <tr>
             <td><input type="checkbox"></td>
             <td>選項一</td>
         </tr>
         <tr>
             <td><input type="checkbox"></td>
             <td>選項二</td>
         </tr>
         <tr>
             <td><input type="checkbox"></td>
             <td>選項三</td>
         </tr>
         <tr>
             <td><input type="checkbox"></td>
             <td>選項四</td>
         </tr>
     </table>

</div>
</body>
<script>
    function select(choice){
		//獲取table元素
        var table=document.getElementById("Table");
		//獲取table下面的全部input標籤
        var inputs=table.getElementsByTagName("input");
		//循環input標籤
        for (var i=0;i<inputs.length;i=i+1){
			//針對每一個input
            var element_input=inputs[i];
			//若是爲全選,則每一個input都爲true
            if (choice=="all"){
                element_input.checked=true;
			//若是爲取消,則每一個input都爲false
            }else if(choice=="cancel"){
                element_input.checked=false;
            }
			//若是爲反選,則將selected的取消便可。
            else {

                if (element_input.checked){
                    element_input.checked=false;
                }else {
                    element_input.checked=true;
                }
            }

            }
    }
</script>
</html>

  

三、多級聯動

實現效果:

代碼:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>小白教程</title>
<style>
   select{
		width:150px;
   }
</style>
</head>
<body>
<select id="province"></select>
<select id="city"></select>
</body>

<script>
//定義數據
    data={"請選擇省":["請選擇市"],"湖南省":["長沙","益陽","常德","湘潭","寧鄉"],"珠海":["香洲區","金灣區","斗門區"]};

//獲取省、市標籤
      var p=document.getElementById("province");
      var c=document.getElementById("city");
 //建立option
    for(var i in data){
        var option_pro=document.createElement("option");

        option_pro.innerHTML=i;

        p.appendChild(option_pro);
    }
//省的option有變化,則建立市的option
     p.onchange=function(){

            pro=(this.options[this.selectedIndex]).innerHTML;
            citys=data[pro];

         c.options.length=0;

         for (var i in citys){
             var option_city=document.createElement("option");
             option_city.innerHTML=citys[i];
             c.appendChild(option_city);
         }

        }
</script>
</html>

  

四、模擬隨機碼

 

 

 代碼以下:

<!doctype html>
<html>
<head>
<meta charset="gb2312">
<title>小白教程</title>
<style>
.v_code {
  width: 600px;
  margin: 0 auto;
}
.v_code > input {
  width: 60px;
  height: 36px;
  margin-top: 10px;
}
.code_show {
  overflow: hidden;
}
.code_show span {
  display: block;
  float: left;
  margin-bottom: 10px;
}
.code_show a {
  display: block;
  float: left;
  margin-top: 10px;
  margin-left: 10px;
}
.code {
  font-style: italic;
  background-color: #f5f5f5;
  color: blue;
  font-size: 30px;
  letter-spacing: 3px;
  font-weight: bolder;
  float: left;
  cursor: pointer;
  padding: 0 5px;
  text-align: center;
}
#inputCode {
  width: 100px;
  height: 30px;
}
a {
  text-decoration: none;
  font-size: 12px;
  color: #288bc4;
  cursor: pointer;
}
a:hover {
  text-decoration: underline;
}
</style>
<script>
var code;
function createCode() {
  code = "";
  var codeLength = 6; //驗證碼的長度
  var checkCode = document.getElementById("checkCode");
  var codeChars = new Array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
       'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z',
       'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z');
  for (var index = 0; index < codeLength; index++) {
    var charNum = Math.floor(Math.random() * 52);
    code += codeChars[charNum];
  }
  if (checkCode) {
    checkCode.className = "code";
    checkCode.innerHTML = code;
  }
}
function validateCode() {
  var inputCode = document.getElementById("inputCode").value;
  var textShow = document.getElementById("text_show")
  if (inputCode.length <= 0) {
    textShow.innerHTML = "請輸入驗證碼";
    textShow.style.color = "red";
  } else if (inputCode.toUpperCase() != code.toUpperCase()) {
    textShow.innerHTML = "您輸入的驗證碼有誤";
    textShow.style.color = "red";
    createCode();
  } else {
    textShow.innerHTML = "驗證碼正確";
    textShow.style.color = "green";
  }
}
function checkCode(){
  var btn = document.getElementById("Button1");
  btn.onclick=function(){
    validateCode();
  }
}
window.onload = function () {
  checkCode();
  createCode();
  document.getElementById("checkCode").onclick = function () { createCode() }
  linkbt.onclick = function () { createCode() }
  inputCode.onclick = function () { validateCode(); }
}
</script>
</head>
<body>
  <div class="v_code">
    <div class="code_show">
      <span class="code" id="checkCode"></span>
      <a id="linkbt">看不清換一張</a>
    </div>
    <div class="input_code">
      <label for="inputCode">驗證碼:</label>
      <input type="text" id="inputCode"/>
      <span id="text_show"></span>
    </div>
    <input id="Button1" type="button" value="肯定" />
  </div>
</body>
</html>

  

五、選項轉移

實現代碼:

<!doctype html>
<html>
<head>
<meta charset="gb2312">
<title>小白教程</title>
<style>
 #left{
	float:left;
	margin-top:50px;
	margin-left:50px;
 }
 #choice{
	float:left;
	margin-top:50px;
 }
 #right{
	float:left;
	margin-top:50px;
 }
 #outer{
	width:300px;
	height:300px;
	border:1px solid red;
	margin-left:100px;
}
</style>
</head>
<body>
<div id='outer'>
 <div id="box1">
    <select multiple="multiple" size="10" id="left">
        <option>user01</option>
        <option>user02</option>
        <option>user03</option>
        <option>user04</option>
        <option>user05</option>
        <option>user06</option>
    </select>
</div>


<div id="choice">
    <input class="add" type="button" value="-添加-->" onclick="add('right','left',false)"><br>
    <input class="remove" type="button" value="<-反加--" onclick="add('left','right',false)"><br>
    <input class="addall" type="button" value="=添加全部==>" onclick="add('right','left',true)"><br>
    <input class="removeall" type="button" value="<==反添加全部=" onclick="add('left','right',true)">
</div>


<div>
    <select multiple="multiple" size="10" id="right">
        <option>user001</option>
		<option>user002</option>
		<option>user003</option>
		<option>user004</option>
		<option>user005</option>
		<option>user006</option>
    </select>
</div>
</div>

</body>
<script>

function add(arg1,arg2,arg3=false){
	var arg1=document.getElementById(arg1);
	var options=document.getElementById(arg2).getElementsByTagName("option");
	for (var i=0; i<options.length;i++){
		var option=options[i];
		if(arg3==false){
			if(option.selected==true){
				arg1.appendChild(option);
				i--;
			}
		}else{
			arg1.appendChild(option);
			i--;
		}            
	 }
 }
</script>
</html>
相關文章
相關標籤/搜索