Knockout结合Bootstrap创建动态UI实现产品列表管理


Posted in Javascript onSeptember 14, 2016

本篇文章结合Bootstrap创建一个比较完整的应用,对产品列表进行管理,包括产品的增加、删除、修改。 

需要的引用 

<script type='text/javascript' src='http://www.see-source.com/js/knockout-2.2.0.js'></script>
<script type='text/javascript' src='http://www.see-source.com/js/jquery-1.6.2.min.js'></script>
<link href="http://www.see-source.com/bootstrap/css/bootstrap.css" rel="stylesheet">

Html代码 

<body>
<!-- 动态生成产品列表 -->
<table class="table table-bordered">
 <thead>
  <tr>
   <th>ID</th>
   <th>产品名称</th>
   <th>原价</th>
   <th>促销价</th>
   <th>操作</th>
  </tr>
 </thead>
 <tbody data-bind="foreach: products">
  <tr > 
   <td> 
   <span data-bind="text: $data.Id"></span> 
   </td> 
   <td> 
   <input type="text" data-bind="value: $data.Name"/> 
   </td> 
   <td>
   <input type="text" data-bind="value: $data.Price"/> 
   </td> 
   <td> 
   <input type="text" data-bind="value: $data.ActualCost"/> 
   </td> 
   <td> 
   <input type="button" class="btn" value="修改" data-bind="click: $root.update"/> 
   <input type="button" class="btn" value="删除" data-bind="click: $root.remove"/> 
   </td> 
  </tr> 
 </tbody>
</table>
<!-- 产品添加form -->
<form class="form-horizontal" data-bind="submit:$root.create">
  <fieldset>
   <legend>添加产品</legend>
   <div class="control-group">
   <label class="control-label" for="input01">产品名称</label>
   <div class="controls">
    <input type="text" name="Name" class="input-xlarge">
   </div>
   </div>
   <div class="control-group">
   <label class="control-label" for="input01">原价</label>
   <div class="controls">
    <input type="text" name="Price" class="input-xlarge">
   </div>
   </div>
   <div class="control-group">
   <label class="control-label" for="input01">促销价</label>
   <div class="controls">
    <input type="text" name="ActualCost" class="input-xlarge">
   </div>
   </div> 
   
   
   <div class="form-actions">
   <button type="submit" class="btn btn-primary">保存</button>
   <button class="btn">取消</button>
   </div>
  </fieldset>
</form>
</body>

js代码 

<script type="text/javascript">
function ProductsViewModel() { 
 var baseUri = 'http://localhost:8080/knockout/'; 
 var self = this; 
 //self.products = ko.observableArray([{'Id':'111','Name':'联想K900','Price':'3299','ActualCost':'3000'},{'Id':'222','Name':'HTC one','Price':'4850','ActualCost':'4500'}]); 
  self.products = ko.observableArray();
 
 $.getJSON(baseUri + "list", self.products);//加载产品列表

 //添加产品
 self.create = function (formElement) {    
  $.post(baseUri + "add", $(formElement).serialize(), function(data) {
    if(data.success){//服务器端添加成功时,同步更新UI
    var newProduct = {};
    newProduct.Id = data.ID;
    newProduct.Name = formElement.Name.value;
    newProduct.Price = formElement.Price.value; 
    newProduct.ActualCost = formElement.ActualCost.value; 
    self.products.push(newProduct);
    }
  },"json"); 
 } 
 //修改产品
 self.update = function (product) {
  $.post(baseUri + "update", product, function(data) {
    if(data.success){
     alert("修改成功");
    }
  },"json"); 
 } 
 
 //删除产品
 self.remove = function (product) { 
  $.post(baseUri + "delete", "productID="+product.Id, function(data) {
    if(data.success){
    //服务器端删除成功时,UI中也删除
    self.products.remove(product);
    }
  },"json"); 
  
 } 
}
ko.applyBindings(new ProductsViewModel());

</script>

如果大家还想深入学习,可以点击这里进行学习,再为大家附3个精彩的专题:

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

Javascript 相关文章推荐
DHTML Slide Show script图片轮换
Mar 03 Javascript
如何使用JS获取IE上传文件路径(IE7,8)
Jul 08 Javascript
js判断选择时间不能小于当前时间的示例代码
Sep 24 Javascript
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
Nov 14 Javascript
JQuery给元素绑定click事件多次执行的解决方法
May 29 Javascript
javascript数组操作方法小结和3个属性详细介绍
Jul 05 Javascript
AngularJs $parse、$eval和$observe、$watch详解
Sep 21 Javascript
微信小程序中用WebStorm使用LESS
Mar 08 Javascript
利用node.js+mongodb如何搭建一个简单登录注册的功能详解
Jul 30 Javascript
vue.js整合mint-ui里的轮播图实例代码
Dec 27 Javascript
基于IView中on-change属性的使用详解
Mar 15 Javascript
Vue.js 事件修饰符的使用教程
Nov 01 Javascript
js注入 黑客之路必备!
Sep 14 #Javascript
AngularJS 模块化详解及实例代码
Sep 14 #Javascript
AngularJS 过滤与排序详解及实例代码
Sep 14 #Javascript
AngularJS  自定义指令详解及实例代码
Sep 14 #Javascript
AngularJS 自定义过滤器详解及实例代码
Sep 14 #Javascript
AngularJS 中的Promise --- $q服务详解
Sep 14 #Javascript
AngularJS bootstrap启动详解及实例代码
Sep 14 #Javascript
You might like
php中的一个中文字符串截取函数
2007/02/14 PHP
PHP中使用glob函数实现一句话删除某个目录下的所有文件
2014/07/22 PHP
php输出xml必须header的解决方法
2014/10/17 PHP
php读取csv数据保存到数组的方法
2015/01/03 PHP
phpMyAdmin无法登陆的解决方法
2017/04/27 PHP
jQuery TextBox自动完成条
2009/07/22 Javascript
基于jQuery制作迷你背词汇工具
2010/07/27 Javascript
ToolTips JQEURY插件之简洁小提示框效果
2011/11/19 Javascript
Javascript变量作用域详解
2013/12/06 Javascript
一个获取第n个元素节点的js函数
2014/09/02 Javascript
js实现同一页面多个不同运动效果的方法
2015/04/10 Javascript
JavaScript动态改变div属性的实现方法
2015/07/22 Javascript
javascript中的正则表达式使用详解
2015/08/30 Javascript
轻松理解Javascript变量的相关问题
2017/01/20 Javascript
在angular 6中使用 less 的实例代码
2018/05/13 Javascript
微信小程序mpvue点击按钮获取button值的方法
2019/05/29 Javascript
javascript面向对象程序设计实践常用知识点总结
2019/07/29 Javascript
vue.js 解决v-model让select默认选中不生效的问题
2020/07/28 Javascript
Python生成随机密码
2015/03/10 Python
使用Python编写基于DHT协议的BT资源爬虫
2016/03/19 Python
win10环境下python3.5安装步骤图文教程
2017/02/03 Python
符合语言习惯的 Python 优雅编程技巧【推荐】
2018/09/25 Python
python绘制热力图heatmap
2020/03/23 Python
Python从数据库读取大量数据批量写入文件的方法
2018/12/10 Python
pandas中ix的使用详细讲解
2020/03/09 Python
Keras SGD 随机梯度下降优化器参数设置方式
2020/06/19 Python
CSS3网格的三个新特性详解
2014/04/04 HTML / CSS
以太网Ethernet IEEE802.3
2013/08/05 面试题
国际贸易专业个人职业生涯规划
2014/02/15 职场文书
副总经理任命书
2014/06/05 职场文书
人力资源管理毕业生自荐信
2014/06/26 职场文书
党的群众路线教育实践活动心得体会(教师)
2014/10/31 职场文书
Python 如何安装Selenium
2021/05/06 Python
在Spring-Boot中如何使用@Value注解注入集合类
2021/08/02 Java/Android
nginx常用配置conf的示例代码详解
2022/03/21 Servers
GO语言字符串处理函数之处理Strings包
2022/04/14 Golang