angular40-angular实现todolist3编辑功能

简介: angular40-angular实现todolist3编辑功能

demo497.html

<!DOCTYPE html>
     <html lang="en">
     <head>
         <meta charset="UTF-8">
         <meta name="viewport" content="width=device-width, initial-scale=1.0">
         <title>Document</title>
     </head>
     <body ng-app="MyToDoMvc">
         <section class="todoapp" ng-controller="MainController">
             <header class="header">
                 <h1>todos</h1>
                 <form ng-submit='add()'>
                     <input class="new-todo" placeholder="what needs to be done" ng-model="text" autofocus>
                 </form>
             </header>
             <!-- <input class="new-todo" placeholder="what needs to be done" ng-model="text" autofocus> -->
             <section class="main">
                 <input class="toggle-all" type="checkbox">
                 <label for="toggle-all">Mark all as complete</label>
                 <ul class="todo-list">
                     <li ng-repeat="todo in todos" ng-class={completed:todo.completed,editing:todo.id===currentEditimgId} data-id="{{todo.id}}">
                         <div class="view">
                             <input class="toggle" type="checkbox" ng-model="todo.completed">
                             <label ng-dblclick="editing(todo.id)">{{todo.text}}</label>
                             <button class="destroy" ng-click="remove(todo.id)">删除</button>
                         </div>
                         <form ng-submit="save()">
                             <input type="edit" ng-model="todo.text">
                         </form>
                     </li>
                     <!--   <li>
                     <div class="view">
                         <input class="toggle" type="checkbox">
                         <label>Buy a unicorn</label>
                         <button class="destroy"></button>
                     </div>
                     <input type="edit" value="Rule the web">
                 </li> -->
                 </ul>
             </section>
             <footer class="footer">
                 <span class="todo-count"><strong>{{todos.length}}</strong>item left</span>
                 <button class="clear-completed" ng-click="clear()" ng-show="existCompleted()">clear</button>
             </footer>
         </section>
         <script src="./node_modules/angular/angular.js"></script>
         <script src="./js/mvc.js"></script>
         <script>
         </script>
     </body>
     </html>.mvc.js
    (function(angular) {
         'use strict';
         /* 应用程序主要的模块 */
         var myApp = angular.module('MyToDoMvc', []);
         //注册一个主要的控制器
         myApp.controller('MainController', ['$scope', function($scope) {
             //复杂的递归 保证id不重复
             function getId() {
                 var id = Math.random();
                 for (var i = 0; i < $scope.todos.length; i++) {
                     if ($scope.todos[i].id === id) {
                         id = getId();
                         break;
                     }
                 }
                 return id;
             }
             //文本框模型
             $scope.text = '';
             //任务列表模型{id 1.text '学习' completed:trur}
             $scope.todos = [{
                     id: 1,
                     text: '学习',
                     completed: false,
                     editing: false
                 },
                 {
                     id: 2,
                     text: '睡觉',
                     completed: false,
                     editing: false
                 },
                 {
                     id: 3,
                     text: '打豆豆',
                     completed: true,
                     editing: false
                 }
             ];
             //添加元素
             $scope.add = function() {
                     $scope.todos.push({
                         id: $scope.todos.length + 1,
                         text: $scope.text,
                         completed: false
                     });
                     //清空文本数据
                     $scope.text = '';
                 }
                 //处理删除
             $scope.remove = function(id) {
                 //删除谁
                 //寻找
                 for (var i = 0; i < $scope.todos.length; i++) {
                     if ($scope.todos[i].id === id) {
                         $scope.todos.splice(i, 1);
                         break;
                     }
                     /* if (1 === a) {
                     } */
                 }
                 //$scope.todos
             }
             $scope.clear = function() {
                     var result = [];
                     for (var i = 0; i < $scope.todos.length; i++) {
                         if (!$scope.todos[i].completed) {
                             result.push($scope.todos[i]);
                         }
                         /* if (1 === a) {
                         } */
                     }
                     $scope.todos = result;
                 }
                 //是否已经由完成的
             $scope.existCompleted = function() {
                     //该函数一定要有返回值    
                     for (var i = 0; i < $scope.todos.length; i++) {
                         if ($scope.todos[i].completed) {
                             return true;
                         }
                         /* if (1 === a) {
                         } */
                     }
                     return false;
                 }
                 //当前编辑哪个元素
             $scope.currentEditimgId = -1;
             $scope.editing = function(id) {
                 $scope.currentEditimgId = id;
             }
             $scope.save = function(id) {
                 $scope.currentEditimgId = -1;
             }
         }])
     })(angular);

image.png

相关文章
|
6月前
【实用】Angular中如何实现类似Vuex的全局变量状态变化功能?
【实用】Angular中如何实现类似Vuex的全局变量状态变化功能?
|
JavaScript 前端开发 API
Angular1.4.6框架简单读取数据库信息并渲染完成news新闻文章列表以及detail详情页功能(小试牛刀)
Angular1.4.6框架简单读取数据库信息并渲染完成news新闻文章列表以及detail详情页功能(小试牛刀)
|
JavaScript
angular实现全选,反选,批量删除,删除,全不选,倒序,模糊查找等功能
angular实现全选,反选,批量删除,删除,全不选,倒序,模糊查找等功能
101 0
|
JavaScript Shell API
Angular5.1以及更多可用功能
我们很高兴的宣布Angular5.1版本发布了。这是一个小版本,包含几个小的功能和bug修复。我们也发布了Angular Cli的1.6版本,以及Angular Material的第一个稳定版本。
1354 0
|
3月前
|
API 开发者 UED
PrimeFaces:JSF的魔法衣橱,解锁UI设计的无限可能!
【8月更文挑战第31天】本文介绍如何结合 JSF(JavaServer Faces)和 PrimeFaces 构建美观且功能强大的现代用户界面。PrimeFaces 提供丰富的 UI 组件库,包括按钮、输入框、数据网格等,支持现代 Web 标准,简化界面开发。文章通过具体示例展示如何使用 `&lt;p:inputText&gt;` 和 `&lt;p:calendar&gt;` 等组件创建用户表单,并用 `&lt;p:dataTable&gt;` 展示数据集合,提升 JSF 应用的易用性和开发效率。
60 0
|
3月前
|
开发者 安全 SQL
JSF安全卫士:打造铜墙铁壁,抵御Web攻击的钢铁防线!
【8月更文挑战第31天】在构建Web应用时,安全性至关重要。JavaServer Faces (JSF)作为流行的Java Web框架,需防范如XSS、CSRF及SQL注入等攻击。本文详细介绍了如何在JSF应用中实施安全措施,包括严格验证用户输入、使用安全编码实践、实施内容安全策略(CSP)及使用CSRF tokens等。通过示例代码和最佳实践,帮助开发者构建更安全的应用,保护用户数据和系统资源。
52 0
|
3月前
|
开发者 C# C++
揭秘:如何轻松驾驭Uno Platform,用C#和XAML打造跨平台神器——一步步打造你的高性能WebAssembly应用!
【8月更文挑战第31天】Uno Platform 是一个跨平台应用程序框架,支持使用 C# 和 XAML 创建多平台应用,包括 Web。通过编译为 WebAssembly,Uno Platform 可实现在 Web 上运行高性能、接近原生体验的应用。本文介绍如何构建高效的 WebAssembly 应用:首先确保安装最新版本的 Visual Studio 或 VS Code 并配置 Uno Platform 开发环境;接着创建新的 Uno Platform 项目;然后通过安装工具链并使用 Uno WebAssembly CLI 编译应用;最后添加示例代码并测试应用。
107 0
|
3月前
|
前端开发 开发者 安全
JSF支付功能大揭秘:探索如何在Java世界中实现安全无缝的在线支付体验
【8月更文挑战第31天】在电子商务和在线交易日益普及的今天,实现在线支付功能已成为许多Web应用的必备需求。JavaServer Faces (JSF) 作为一种流行的Java Web框架,提供了丰富的组件和工具来构建用户界面,包括与支付网关集成以实现在线支付。支付网关是处理信用卡和借记卡支付的系统,在商家和银行之间起到桥梁作用。本文将探讨如何使用JSF与支付网关集成,以及实现在线支付功能时需要考虑的关键点
46 0
|
3月前
|
开发者 前端开发 开发框架
JSF与移动应用,开启全新交互体验!让你的Web应用轻松征服移动设备,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,移动设备的普及使得构建移动友好的应用变得至关重要。尽管JSF(JavaServer Faces)主要用于Web应用开发,但结合Bootstrap等前端框架,也能实现优秀的移动交互体验。本文探讨如何在JSF应用中实现移动友好性,并通过示例代码展示具体实现方法。使用Bootstrap的响应式布局和组件可以确保JSF页面在移动设备上自适应,并提供友好的表单输入和提交体验。尽管JSF存在组件库较小和学习成本较高等局限性,但合理利用其特性仍能显著提升用户体验。通过不断学习和实践,开发者可以更好地掌握JSF应用的移动友好性,为Web应用开发贡献力量。
52 0