js + bootstrap 实现基本的增删改查功能 -- 兰

描述:利用原生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">
                  &times;
            </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>

<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");
    }
}

时间: 2024-10-14 17:56:53

js + bootstrap 实现基本的增删改查功能 -- 兰的相关文章

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

开心一笑 听说这两天,全国都很冷.福建人说1度好冷,北京人笑了:我们这零下17度.黑龙江人也笑了:我们这零下33度.呼伦贝尔人听到哈哈大笑:我们这零下43度.福建人听完冷笑一声:我说的是室内,室内,室内 提出问题 如何利用原生的js实现基本的增删改查功能 解决问题 包含两个文件(index.jsp 和 index.js) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEn

使用MVC5+Entity Framework6的Code First模式创建数据库并实现增删改查功能

此处采用VS2017+SqlServer数据库 一.创建项目并引用dll: 1.创建一个MVC项目 2.采用Nuget安装EF6.1.3 二.创建Model 在models文件夹中,建立相应的model文件,这里建立的class名,就是数据库里表的名字.        在这里面,可以建立表之间的关系,本次将建立Course(课程).Student(学生).StuCourse(课程学生关系)来作为一个Demo [Table("t_course")]   //可以通过Attribute的形

SQLite实现基本的增删改查功能

SQLite实现基本的增删改查功能 还是向之前一样,先介绍功能,再介绍所用知识点,然后贴下代码. 一,SQLite简介: SQLite,是一款轻型的数据库,是遵守ACID(原子性.一致性.隔离性.持久性)的关联式数据库管理系统,多用于嵌入式开发中.   SQLite的数据类型:Typelessness(无类型), 可以保存任何类型的数据到你所想要保存的任何表的任何列中. 但它又支持常见的类型比如: NULL, VARCHAR, TEXT, INTEGER, BLOB, CLOB...等. 唯一的

java H2数据库使用并实现增删改查功能

原文:java H2数据库使用并实现增删改查功能 代码下载地址:http://www.zuidaima.com/share/1550463278058496.htm package com.zuidaima.h2sql.test; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.St

JavaWeb 增删改查功能

1.今天来写一个简单的增删改查功能,这个项目还是接着在昨天写的 --JavaWeb实现简单登录注册-- 来写的. 登录成功进来后对学生信息的增删改查 好了,直接贴上今天写的代码 src文件下的代码: jsp页面: 数据库创建语句: 1 CREATE TABLE nanfeng.student ( 2 stu_id INT NOT NULL AUTO_INCREMENT, 3 stu_name varchar(100) NULL, 4 stu_sex varchar(100) NULL, 5 st

3.创建Manager类,演示对TestUser进行增删改查功能

接上一篇文章 创建NHibernateHelper帮助类,生成sessionFactory http://www.cnblogs.com/fzxiaoyi/p/8443587.html 创建个新的类Manager,演示对TestUser进行增删改查功能 编写代码如下: using MySQLDateBase.Model; using System; using System.Collections.Generic; using System.Linq; using System.Text; us

SpringBoot快速上手——《二》:SpringBoot集成SSM,实现增删改查功能

SpringBoot集成SSM,实现增删改查功能 github源码:https://github.com/xivinChen/SpringBoot 一.先介绍创建模块的另一种方式 1.点击Maven -> 勾选Create from archetype -> 选择 maven-archetype-quickstart 有时会需要点击 自动导入 2.工程目录 可以看到,这样创建的模块是相对干净的,需要我们手动的编写程序启动入口类.需要配置时还得创建配置文件.下一步见证. 3.完善模块 添加依赖,

使用JS对HTML标签进行增删改查

以下为通过JS对li标签进行简单的增删改查: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <script typ

Mock.js简易教程,脱离后端独立开发,实现增删改查功能

在我们的生产实际中,后端的接口往往是较晚才会出来,并且还要写接口文档,于是我们的前端的许多开发都要等到接口给我们才能进行,这样对于我们前端来说显得十分的被动,于是有没有可以制造假数据来模拟后端接口呢,答案是肯定的.应该有人通过编写json文件来模拟后台数据,但是很局限,比如增删改查这些接口怎么实现呢,于是今天我们来介绍一款非常强大的插件Mock.js,可以非常方便的模拟后端的数据,也可以轻松的实现增删改查这些操作. 1.一个简单的例子: Mock.mock('http://123.com',{