AngularJS 待办事项 App

下面是一个完整的 AngularJS 示例 App ,实现一个简单的待办事项清单(To-Do List) ,你可以直接复制粘贴到 .html 文件中运行:


✅ 示例:AngularJS 待办事项 App

复制代码
<!DOCTYPE html>
<html ng-app="todoApp">
<head>
  <meta charset="UTF-8">
  <title>AngularJS ToDo App</title>
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.8.2/angular.min.js"></script>
  <style>
    body { font-family: Arial; padding: 20px; }
    ul { list-style-type: none; padding: 0; }
    li { margin: 5px 0; }
    .completed { text-decoration: line-through; color: gray; }
  </style>
</head>
<body ng-controller="TodoController">

  <h1>我的待办事项</h1>

  <input type="text" ng-model="newTask" placeholder="添加新任务" />
  <button ng-click="addTask()">添加</button>

  <ul>
    <li ng-repeat="task in tasks">
      <input type="checkbox" ng-model="task.done"> 
      <span ng-class="{completed: task.done}">{{ task.text }}</span>
      <button ng-click="removeTask($index)">删除</button>
    </li>
  </ul>

  <p>剩余任务:{{ remaining() }}</p>

  <script>
    var app = angular.module('todoApp', []);
    app.controller('TodoController', function($scope) {
      $scope.tasks = [
        { text: '学习 AngularJS', done: false },
        { text: '做一个示例 App', done: true }
      ];

      $scope.addTask = function() {
        if ($scope.newTask) {
          $scope.tasks.push({ text: $scope.newTask, done: false });
          $scope.newTask = '';
        }
      };

      $scope.removeTask = function(index) {
        $scope.tasks.splice(index, 1);
      };

      $scope.remaining = function() {
        var count = 0;
        angular.forEach($scope.tasks, function(task) {
          if (!task.done) count++;
        });
        return count;
      };
    });
  </script>

</body>
</html>

🧠 你可以学到:

功能 AngularJS 语法
数据绑定 {``{ task.text }}
控制器 ng-controller="TodoController"
模型绑定 ng-model="newTask"
列表渲染 ng-repeat="task in tasks"
条件样式 ng-class="{completed: task.done}"
事件处理 ng-click="addTask()"

运行结果如下:

相关推荐
编程牛马姐16 分钟前
独立站SEO流量增长:提高Google排名的优化方法
前端·javascript·网络
NotFound48633 分钟前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
Dontla1 小时前
高基数(High Cardinality)问题介绍(Prometheus、高基数字段、低基数字段)
前端·数据库·prometheus
whuhewei3 小时前
为什么客户端不存在跨域问题
前端·安全
妮妮喔妮3 小时前
supabase的webhook报错
开发语言·前端·javascript
qq_12084093714 小时前
Three.js 大场景分块加载实战:从全量渲染到可视集调度
开发语言·javascript·数码相机
yivifu4 小时前
手搓HTML双行夹批效果
前端·html·html双行夹注
奔跑的卡卡5 小时前
Web开发与AI融合-第一篇:Web开发与AI融合的时代序幕
前端·人工智能
IT_陈寒5 小时前
Redis批量删除的大坑,差点让我加班到天亮
前端·人工智能·后端
帆张芳显5 小时前
智表ZCELL产品V3.6 版发布,新增系统预置右键菜单操作、页签栏操作等功能
前端·canva可画·excel插件