亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

        JS結合bootstrap實現(xiàn)基本的增刪改查功能

        字號:


            這篇文章主要介紹了JS結合bootstrap實現(xiàn)基本的增刪改查功能,需要的朋友可以參考下
            提出問題:如何利用原生的js實現(xiàn)基本的增刪改查功能???
            解決問題
            假如你已經(jīng)對JS有一定基礎
            假如你對bootstrap有一定基礎
            下面是具體的例子,
            包含兩個文件(index.jsp  和  index.js)
            <%@ page language="java" contentType="text/html; charset=UTF-8"
            pageEncoding="UTF-8"%>
             <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
             <html>
             <head>
             <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
             <!-- Bootstrap -->
             <link href="resource/bootstrap/css/bootstrap.min.css" rel="stylesheet" media="screen">
             <link href="resource/bootstrap/css/bootstrap-theme.min.css" rel="stylesheet" media="screen">
             <title>JS框架學習</title>
             </head>
             <body onload="loadUserDatas()">
             <div>
             <table id="table">
              <caption><h2>練習一</h2></caption>
              <caption>
                <button type="button" id="user_add" data-toggle="modal"
              data-target="#myModal" onclick="optionUserData(this);">新增</button>
                <button type="button" id="user_delete" onclick="optionUserData(this);">刪除</button>
                <button type="button" id="user_edit" data-toggle="modal"
              data-target="#myModal" onclick="optionUserData(this);">編輯</button>
                <button type="button" id="user_find" onclick="optionUserData(this);">查詢</button>
                <input type="text" id="s_code" placeholder="按工號查詢">
                <input type="text" id="s_userName" placeholder="按姓名查詢">
                <input type="text" id="s_all" placeholder="全文搜索">
              </caption>
              <thead>
               <tr>
                <th>序號</th>
                <th>工號</th>
                <th>姓名</th>
                <th>性別</th>
                <th>密碼</th>
                <th>年齡</th>
                <th>出生日期</th>
               </tr>
              </thead>
              <tbody id="tbody">
              </tbody>
             </table>
             <!-- 模態(tài)框(Modal) -->
             <div id="myModal" role="dialog" >
              <div>
               <div>
                <div>
                <button type="button" data-dismiss="modal" aria-hidden="true"> 
                  ×
                </button>
                <h4 id="myModalLabel">
                  新增用戶
                </h4>
                </div>
                <div id="modal-body">
                <label for="name">工號:</label>
                 <input type="text" id="m_code" placeholder="請輸入工號">
                 <label for="name">姓名:</label>
                 <input type="text" id="m_userName" placeholder="請輸入姓名">
                 <label for="name">性別:</label>
                 <input type="text" id="m_sex" placeholder="請輸入性別">
                 <label for="name">密碼:</label>
                 <input type="text" id="m_passWord" placeholder="請輸入密碼">
                 <label for="name">年齡:</label>
                 <input type="text" id="m_age" placeholder="請輸入年齡">
                 <label for="name">出生日期:</label>
                 <input type="text" id="m_birthday" placeholder="請輸入出生日期">
                </div>
                <div>
                <button type="button"
                 data-dismiss="modal">保存
                </button>
                <button type="button">提交更改</button>
                </div>
               </div><!-- /.modal-content -->
             </div><!-- /.modal -->
             </div>
             <!-- 這里需要引入相關的js,很重要,請記住 -->
             <script type="text/javascript" src="resource/jquery/jquery.js"></script>
             <script type="text/javascript" src="resource/bootstrap/js/bootstrap.min.js"></script>
             <script type="text/javascript" src="index.js"></script>
             </body>
             </html>
             復制代碼
             復制代碼
             //存放所有用戶
             var users = users || {};
             //操作類型
             var operateType = "";
             //存放搜索對象
             var searchUsers = searchUsers || {};
             //用戶構造方法
             var User = {
               Create:function(code,userName,sex,passWord,age,birthday){
                this.code = code;
                this.userName = userName;
                this.sex = sex;
                this.passWord = passWord;
                this.age = age;
                this.birthday = birthday;
               },
               //添加用戶
               addUserData:function(){
                if(this.code != ""){
                 users[this.code] = this;
                }
               },
               //刪除用戶
               deleteUserData:function (){
                for(var i in users){
                 if(this.code == users[i].code){
                  delete users[i];
                 }
                }
               },
               //編輯用戶
               editUserData:function(){
                for(var i in users){
                 if(this.code == users[i].code){
                  users[i].userName = this.userName;
                  users[i].sex = this.sex;
                  users[i].passWord = this.passWord;
                  users[i].birthday = this.birthday;
                  users[i].age = this.age;
                 }
                }
               },
               //查找用戶
               findUserData:function(data){
                for(var i in users){
                 if(data.code.indexOf(users[i].code) >= 0 || 
                   data.userName.indexOf(users[i].userName) >= 0){
                  searchUsers[users[i].code] = users[i];
                  refreshDatas(searchUsers);
                 }
                }
               }
             };
             function New(aClass,aParams){
              function new_(){
               aClass.Create.apply(this,aParams);
              }
              new_.prototype = aClass;
              return new new_();
             }
             //bootstrap模態(tài)框事件
             $('#myModal').on('hide.bs.modal', function () {
              // 執(zhí)行一些動作...
              var inputElements = this.getElementsByTagName("input");
              var userArr = [];
              for(var i=0;i<inputElements.length;i++){
               userArr[i] = inputElements[i].value;
              }
              var user = New(User,userArr);
              //添加操作
              if(operateType == "add"){
               user.addUserData();
               refreshDatas(users);
              //編輯操作
              }else if(operateType == "edit"){
               user.editUserData();
               refreshDatas(users);
              }
             });
             /**
              * 首次加載頁面執(zhí)行方法
              */
             function loadUserDatas(){
              var userArray = initUserDatas();
              addRowData(userArray);
              refreshDatas(users);
             }
             /**
              * 初始化用戶數(shù)據(jù)
              */
             function initUserDatas(){
              var initUser1 = New(User,["1001","小蘭","女","1234","13","1991-1-1"]);
              var initUser2 = New(User,["1002","小毅","男","1234","13","1991-1-1"]);
              var initUser3 = New(User,["1003","蘭花","女","1234","13","1991-1-1"]);
              var initUser4 = New(User,["1004","蘭兒","女","1234","13","1991-1-1"]);
              users[initUser1.code] = initUser1;
              users[initUser2.code] = initUser2;
              users[initUser3.code] = initUser3;
              users[initUser4.code] = initUser4;
              return users;
             }
             /**
              * 往表格添加一行html數(shù)據(jù)
              */
             function addRowData(datas){
              var tbodyElement = document.getElementById("tbody");
              var html = "";
              var color = "warning";
              var flag = true;
              for(var i in datas){
               if(flag){
                color = "info";
               }else{
                color = "warning";
               }
               html = html + "<tr class='"+ color +"'><td style='width:30px;'><input type='checkbox'></td><td id='code'>"
                 + datas[i].code +"</td><td id='userName'>"
                 + datas[i].userName +"</td><td id='sex'>"
                 + datas[i].sex +"</td><td id='passWord'>"
                 + datas[i].passWord +"</td><td id='age'>"
                 + datas[i].age +"</td><td id='birthday'>"
                 + datas[i].birthday +"</td>" 
                 +"</tr>";
               flag = !flag;//顏色轉(zhuǎn)換
              }
              tbodyElement.innerHTML = html;
             }
             /**
              * 刷新用戶數(shù)據(jù)
              */
             function refreshDatas(datas){
              addRowData(datas);
             };
             /**
              * 收集一行數(shù)據(jù)
              */
             function collectionRowData(param){
              var tdElement = param.getElementsByTagName("td");
              var userArr = [];
              for(var i=1;i<tdElement.length;i++){
               var temp = tdElement[i].textContent;
               userArr[i-1] = temp;
              }
              var user = New(User,userArr);
              return user;
             }
             /**
              * 用戶操作方法
              */
             function optionUserData(param){
              //獲得操作類別
              var optionType = param.getAttribute("id");
              if(optionType == "user_add"){
               operateType = "add";
              }else if(optionType == "user_delete"){
               var checkRowData = isCheckedData();
               var user = collectionRowData(checkRowData);
               user.deleteUserData();
               refreshDatas(users);
              }else if(optionType == "user_edit"){
               operateType = "edit";
               var checkRowData = isCheckedData();
               var user = collectionRowData(checkRowData);
               var modal_body = document.getElementById("modal-body");
               var inputElements= modal_body.getElementsByTagName("input");
               for(var i=0;i<inputElements.length;i++){
                var temp = inputElements[i].id.substring(2,inputElements[i].id.length)
                inputElements[i].value = user[temp];
               }
              }else if(optionType == "user_find"){
               var s_code = document.getElementById("s_code").value;
               var s_userName = document.getElementById("s_userName").value;
               var s_all= document.getElementById("s_all").value;
               //搜索數(shù)據(jù)
               var s_data = s_data || {};
               s_data.code = s_code;
               s_data.userName = s_userName;
               s_data.all = s_all;
               var user = New(User,[]);
               user.findUserData(s_data);
              }else{
              }
             }
             /**
              * 是否選中數(shù)據(jù),返回選中數(shù)據(jù)的行
              */
             function isCheckedData(){
              var tbodyElement =document.getElementById("tbody");
              var trElements = tbodyElement.getElementsByTagName("tr");
              var flag = false;
              for(var i=0;i<trElements.length;i++){
               var inputElement = trElements[i].getElementsByTagName("input")[0];
               if(inputElement.checked){
                flag = true;
                return trElements[i];
               }
              }
              if(!flag){
               alert("請選擇一條記錄!");
               $('#myModal').unbind("on");
              }
             }
            效果圖:
            名單
            以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助