JavaScript之实现基本的增删改查功能

开心一笑

听说这两天,全国都很冷。福建人说1度好冷,北京人笑了:
我们这零下17度。黑龙江人也笑了:我们这零下33度。
呼伦贝尔人听到哈哈大笑:我们这零下43度。
福建人听完冷笑一声:我说的是室内,室内,室内

提出问题

如何利用原生的js实现基本的增删改查功能???

解决问题

假如你已经对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 class="container">
    <table class="table" id="table">
       <caption><h2>练习一</h2></caption>
       <caption>
               <button type="button" class="btn btn-info" id="user_add" data-toggle="modal" 
       data-target="#myModal" onclick="optionUserData(this);">新增</button>
               <button type="button" class="btn btn-info" id="user_delete" onclick="optionUserData(this);">删除</button>
               <button type="button" class="btn btn-info" id="user_edit"  data-toggle="modal" 
       data-target="#myModal"  onclick="optionUserData(this);">编辑</button>
               <button type="button" class="btn btn-info" id="user_find" onclick="optionUserData(this);">查询</button>
               <input type="text" id="s_code" placeholder="按工号查询" style="width: 80px;">
               <input type="text" id="s_userName" placeholder="按姓名查询" style="width: 80px;">
               <input type="text" id="s_all" placeholder="全文搜索" style="width: 80px;">
       </caption>
       <thead>
          <tr>
               <th>序号</th>
             <th>工号</th>
             <th>姓名</th>
             <th>性别</th>
             <th>密码</th>
             <th>年龄</th>
             <th>出生日期</th>
          </tr>
       </thead>
       <tbody id="tbody">
       </tbody>
    </table>
    
    <!-- 模态框(Modal) -->
    <div class="modal hide" id="myModal"  role="dialog" >
       <div class="modal-dialog">
          <div class="modal-content">
             <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal" aria-hidden="true"> 
                      ×
                </button>
                <h4 class="modal-title" id="myModalLabel">
                       新增用户
                </h4>
             </div>
             <div class="modal-body" id="modal-body">
                <label for="name">工号:</label>
                  <input type="text" class="form-control" id="m_code" placeholder="请输入工号">
                  <label for="name">姓名:</label>
                  <input type="text" class="form-control" id="m_userName" placeholder="请输入姓名">
                  <label for="name">性别:</label>
                  <input type="text" class="form-control" id="m_sex" placeholder="请输入性别">
                  <label for="name">密码:</label>
                  <input type="text" class="form-control" id="m_passWord" placeholder="请输入密码">
                 <label for="name">年龄:</label>
                  <input type="text" class="form-control" id="m_age" placeholder="请输入年龄">
                  <label for="name">出生日期:</label>
                  <input type="text" class="form-control" id="m_birthday" placeholder="请输入出生日期">
             </div>
             <div class="modal-footer">
                <button type="button" class="btn btn-default" 
                   data-dismiss="modal">保存
                </button>
                <button type="button" class="btn btn-primary">提交更改</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模态框事件
    $('#myModal').on('hide.bs.modal', function () {
        // 执行一些动作...
        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);
        }
    });
    
    /**
     * 首次加载页面执行方法
     */
    function loadUserDatas(){
        var userArray = initUserDatas();
        addRowData(userArray);
        refreshDatas(users);
        
    }
    /**
     * 初始化用户数据
     */
    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数据
     */
    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;//颜色转换
        }
        tbodyElement.innerHTML = html;
    }
    /**
     * 刷新用户数据
     */
    function refreshDatas(datas){
        addRowData(datas);
    };
    
    /**
     * 收集一行数据
     */
    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;
            //搜索数据
            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{
            
        }
    }
    
    /**
     * 是否选中数据,返回选中数据的行
     */
    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");
        }
    }
运行结果.png

读书感悟

  • 快乐其实就是这样,你愈呼唤它,它就愈不肯造访。但是当你埋头努力的时候,它就不期而遇了

  • 吃饭时吃饭,睡觉时睡觉,是最好的人生态度。

  • 我闷闷不乐,因为我少了一双鞋,直到我在街上,见到有人缺了两条腿。
    如果你从来没有经历过战争的危险,你已经比五亿人幸福了;
    如果你能吃饱,已经比八亿人幸福了;
    如果你有存款,你已经比92%的人幸福了!快乐就是珍惜已拥有的一切!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 她体态轻盈,体型均匀,表情恬淡。身高约1米6,目测体重不到50公斤,特别瘦,感觉一阵大风吹来,就能把她刮走。 她身...
    梅好时光er阅读 391评论 0 0
  • 一字至七字诗·家~ 家。 归来,出发。 桌椅床,暖沙发。 ...
    爱诗的鱼儿阅读 405评论 2 2
  • 太医略一迟疑,倒真不知该如何答复东华。这东华帝君固然是威武霸气,可抢人老婆抢到这份上,是不是也太过分了一点呢? 东...
    无名字阅读 10,338评论 62 66
  • 【翻轉日記,三十五】 被誤讀的動機。自進入民辦高校工作以來我就觀察到這裡的孩子們特別重視社團活動,還有誇張的一個人...
    陈威Jonathan阅读 142评论 0 0