JS结合bootstrap实现基本的增删改查功能

提出问题:如何利用原生的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");
  }
 }

效果图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • JS表格组件神器bootstrap table详解(基础版)

    一.Bootstrap Table的引入 关于Bootstrap Table的引入,一般来说还是两种方法: 1.直接下载源码,添加到项目里面来. 由于Bootstrap Table是Bootstrap的一个组件,所以它是依赖Bootstrap的,我们首先需要添加Bootstrap的引用. 2.使用我们神奇的Nuget 打开Nuget,搜索这两个包 Bootstrap已经是最新的3.3.5了,我们直接安装即可. 而Bootstrap Table的版本竟然是0.4,这也太坑爹了.所以博主建议Boot

  • Angular.js与Bootstrap相结合实现表格分页代码

    先给大家简单介绍angular.js和bootstrap基本概念. AngularJS 是一个 JavaScript 框架.它可通过 <script> 标签添加到 HTML 页面. AngularJS 通过 指令 扩展了 HTML,且通过 表达式 绑定数据到 HTML. Bootstrap,来自 Twitter,是目前最受欢迎的前端框架.Bootstrap 是基于 HTML.CSS.JAVASCRIPT 的,它简洁灵活,使得 Web 开发更加快捷. 最近一直学习Angular.js,在学习过程

  • BootStrap和jQuery相结合实现可编辑表格

    editTable.js 提供编辑表格当前行.添加一行.删除当前行的操作,其中可以设置参数,如: operatePos 用于设置放置操作的列,从0开始,-1表示以最后一列作为放置操作的列:(这里的操作包括 编辑当前行.在当前行下添加一行.删除当前行) handleFirst 设置表格的第一行是否作为操作的对象,true为真,false为假: edit.save.cancel.add.confirm.del 分别设置显示操作的操作名,默认显示"编辑"."保存".&qu

  • BootStrap实现带有增删改查功能的表格(DEMO详解)

    前言 bootstrap的表格样式,有类似EasyUI的表格,也有卡片式表格,放到移动端显示,各有千秋.但是BootStrap自带的表格是没有操作列的,网上的资源不少,但是都是比较单一.零碎,JS.CSS也经常给的不全,自己经过大概一个月左右的时间,把表格封装了一下,希望能分享给大家. 表格封装了3个版本,接下来给大家展示一下样式和代码. 版本一 1. 样式 表格布局: 添加:添加一行新的空白代码 修改:选中可修改的列,点击需要修改的单元格,即可变成可编辑的状态. 2.代码 @using Dat

  • BootstrapTable与KnockoutJS相结合实现增删改查功能【二】

    在上篇文章给大家介绍了BootstrapTable与KnockoutJS相结合实现增删改查功能[一],介绍了下knockout.js的一些基础用法.接下来通过本文继续给大家介绍.如果你也打算用ko去做项目,且看看吧! Bootstrap是一个前端框架,解放Web开发者的好东东,展现出的UI非常高端大气上档次,理论上可以不用写一行css.只要在标签中加上合适的属性即可. KnockoutJS是一个JavaScript实现的MVVM框架.非常棒.比如列表数据项增减后,不需要重新刷新整个控件片段或自己

  • BootstrapTable+KnockoutJS自定义T4模板快速生成增删改查页面

    前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4的语法,虽然没有完全掌握,但是算是有了一个大致的了解.于是乎有了今天的这篇文章:通过T4模板快速生成页面. KnockoutJS系列文章: BootstrapTable与KnockoutJS相结合实现增删改查功能[一] BootstrapTable与KnockoutJS相结合实现增删改查功能[二]

  • BootstrapTable与KnockoutJS相结合实现增删改查功能【一】

    Bootstrap是一个前端框架,解放Web开发者的好东东,展现出的UI非常高端大气上档次,理论上可以不用写一行css.只要在标签中加上合适的属性即可. KnockoutJS是一个JavaScript实现的MVVM框架.非常棒.比如列表数据项增减后,不需要重新刷新整个控件片段或自己写JS增删节点,只要预先定义模板和符合其语法定义的属性即可.简单的说,我们只需要关注数据的存取. 一.Knockout.js简介 1.Knockout.js和MVVM 如今,各种前端框架应接不暇,令人眼花缭乱,有时不得

  • BootstrapTable+KnockoutJS相结合实现增删改查解决方案(三)两个Viewmodel搞定增删改查

    前言:之前博主分享过knockoutJS和BootstrapTable的一些基础用法,都是写基础应用,根本谈不上封装,仅仅是避免了html控件的取值和赋值,远远没有将MVVM的精妙展现出来.最近项目打算正式将ko用起来,于是乎对ko和bootstraptable做了一些封装,在此分享出来供园友们参考.封装思路参考博客园大神萧秦,如果园友们有更好的方法,欢迎讨论. KnockoutJS系列文章: BootstrapTable与KnockoutJS相结合实现增删改查功能[一] BootstrapTa

  • JS结合bootstrap实现基本的增删改查功能

    提出问题:如何利用原生的js实现基本的增删改查功能??? 解决问题 假如你已经对JS有一定基础 假如你对bootstrap有一定基础 下面是具体的例子, 包含两个文件(index.jsp  和  index.js) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC

  • SpringBoot+Vue+Axios+BootStrap实现图书的增删改查功能示例

    目录 一.开发工具 二.项目结构 三.编写项目 四.运行项目 由于是初学Vue.Axios,可能在界面和功能上存在着一些问题,但这些并不妨碍使用.如果有对编程感兴趣的朋友,可以试着做一做.这个由于是第一次做,不太熟练.在后续的过程中会不断的完善. 一.开发工具 IntelliJ IDEA Ultimate 2021.1 apache-maven-3.5.4 MySQL5.7 JDK 1.8.0_281 二.项目结构 三.编写项目 1.创建数据库 SET NAMES utf8mb4; SET FO

  • Vue+Mock.js模拟登录和表格的增删改查功能

    前言 关于mockjs,官网描述的是 1.前后端分离 2.不需要修改既有代码,就可以拦截 Ajax 请求,返回模拟的响应数据. 3.数据类型丰富 4.通过随机数据,模拟各种场景. 5 项目不背锅(等后端给接口的话可能会背锅) 等等优点,最后一条我加的. 第一步先安装mock.js npm install mockjs --save-dev 第二步使用 mock.js import Mock from 'mockjs' 哪里用就在哪里引入.我是在项目src/mock/index.js里面使用moc

  • Jquery与Bootstrap实现后台管理页面增删改查功能示例

    使用jquery与bootstrap实现了一个比较简单但功能齐全的增删改查功能的后台管理页面,虽然只是一个CRUD页面,但麻雀虽小五脏俱全,JS常用的功能都用到了,本例用原生的jquery与bootstrap配合使用,不考虑JS的重构性及打包,该例子零耦合,开箱即用. 先看Demo: 一.用到的Jquery功能 1.获取/赋值input输入值 $("#my_id").val();// 获取 $("#my_id").val("user_id");/

  • vue.js+Element实现表格里的增删改查

    新项目使用的是vue.js 后来发现饿了吗前端编写的一套框架Element (http://element.eleme.io/#/zh-CN)来配合vue.js进行样式填充 之前用过angularjs 用到后来 发现越来越难学 于是就决定用vue.js 下面就介绍一下vue.js应用在表格里的增删改查 首先引入一下element的js <script src="plugins/element-ui/index.js"></script> 然后引入需要用到的vue

  • JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能

    本文实例讲述了JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能.分享给大家供大家参考,具体如下: 单例模式 单例模式的核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中一个类只有一个实例 单例模式最初的定义出现于<设计模式>(艾迪生维斯理, 1994):"保证一个类仅有一个实例,并提供一个访问它的全局访问点." 单例模式定义:"一个类有且仅有一个实例,并且自行实例化向整个系统提供." var Singleton

  • jQuery实现对网页节点的增删改查功能示例

    本文实例讲述了jQuery实现对网页节点的增删改查功能.分享给大家供大家参考,具体如下: 前面介绍过<JavaScript针对网页节点的增删改查用法>,其实JavaScript对DOM的操作已经总结了很久的,而对于jQuery对网页节点的操作,虽然一直在用,但一直没有好好总结一下,实在是不应该. 下面举同样的例子来说明这个问题: 如上图,提供3个按钮,1个下拉列表,1个输入框,提供增删改查的操作. 网页中最多10个节点,最少0个节点,多了不让加,少了不让减. 首先是本网页的基本布局: <

随机推荐