English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Эта статья combines 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 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 интересных темы:
Урок изучения Bootstrap
Практический урок Bootstrap
Урок использования плагинов Bootstrap
Вот и все, что есть в этой статье, я надеюсь, что это поможет вам в изучении, и希望大家多多支持呐喊教程。
Заявление: содержание этой статьи взято из Интернета, авторские права принадлежат соответствующему автору, контент предоставлен пользователями Интернета в добровольном порядке, сайт не имеет права собственности, не прошел редактирование, не несет ответственности за соответствующие юридические вопросы. Если вы обнаружите подозрительное нарушение авторских прав, пожалуйста, отправьте письмо по адресу: notice#oldtoolbag.com (во время отправки письма замените # на @) для сообщения о нарушении,并提供 соответствующие доказательства. Если подтвердится, сайт немедленно удалил涉嫌侵权的内容。