AngularJS示例有哪些?新手如何快速上手学习?

AngularJS 作为一款经典的前端框架,以其数据绑定、依赖注入和模块化特性为开发者提供了高效的开发方式,以下通过具体示例展示其核心功能与应用场景。

AngularJS示例有哪些?新手如何快速上手学习?

数据绑定与双向交互

AngularJS 的核心优势在于双向数据绑定,通过 ng-model 指令实现视图与模型的双向同步,以下示例展示一个简单的用户信息表单:

<div ng-app="myApp" ng-controller="userController">  
  <h3>用户信息</h3>  
  <p>姓名:<input type="text" ng-model="user.name"></p>  
  <p>年龄:<input type="number" ng-model="user.age"></p>  
  <p>自我介绍:<textarea ng-model="user.bio"></textarea></p>  
  <button ng-click="saveUser()">保存信息</button>  
  <div ng-show="message">{{ message }}</div>  
</div>  

对应的 JavaScript 控制器逻辑:

var app = angular.module('myApp', []);  
app.controller('userController', function($scope) {  
  $scope.user = { name: '', age: '', bio: '' };  
  $scope.message = '';  
  $scope.saveUser = function() {  
    $scope.message = '信息已保存:' + JSON.stringify($scope.user);  
  };  
});  

说明

  • ng-model 将输入框的值与 $scope.user 对象绑定,修改输入框内容时模型数据实时更新。
  • ng-show 根据条件控制消息显示,ng-click 绑定按钮点击事件。

列表渲染与循环操作

ng-repeat 指令可高效渲染动态列表,支持过滤和排序,以下示例展示商品列表管理:

<div ng-app="productApp" ng-controller="productController">  
  <input type="text" ng-model="searchText" placeholder="搜索商品">  
  <table border="1" style="width:100%; margin-top:10px;">  
    <thead>  
      <tr>  
        <th ng-click="sort('id')">ID</th>  
        <th ng-click="sort('name')">名称</th>  
        <th ng-click="sort('price')">价格</th>  
      </tr>  
    </thead>  
    <tbody>  
      <tr ng-repeat="product in filteredProducts = (products | filter:searchText | orderBy:sortKey:reverse)">  
        <td>{{ product.id }}</td>  
        <td>{{ product.name }}</td>  
        <td>{{ product.price | currency }}</td>  
      </tr>  
    </tbody>  
  </table>  
</div>  

控制器代码:

AngularJS示例有哪些?新手如何快速上手学习?

var app = angular.module('productApp', []);  
app.controller('productController', function($scope) {  
  $scope.products = [  
    { id: 1, name: '笔记本', price: 4500 },  
    { id: 2, name: '手机', price: 3200 },  
    { id: 3, name: '平板', price: 2800 }  
  ];  
  $scope.sortKey = 'name';  
  $scope.reverse = false;  
  $scope.sort = function(key) {  
    $scope.sortKey = key;  
    $scope.reverse = !$scope.reverse;  
  };  
});  

功能解析

  • filter:searchText 实现基于输入框的实时搜索。
  • orderBy:sortKey:reverse 支持点击表头排序,reverse 控制升序/降序。
  • currency 过滤器将价格格式化为货币形式。

模块化与依赖注入

AngularJS 通过模块化实现功能解耦,依赖注入(DI)简化组件间协作,以下示例展示服务模块的使用:

// 定义商品服务模块  
var app = angular.module('productService', []);  
app.service('ProductService', function() {  
  this.getProducts = function() {  
    return [  
      { id: 1, name: '键盘', price: 199 },  
      { id: 2, name: '鼠标', price: 129 }  
    ];  
  };  
});  
// 主模块依赖服务模块  
var mainApp = angular.module('mainApp', ['productService']);  
mainApp.controller('productCtrl', function($scope, ProductService) {  
  $scope.products = ProductService.getProducts();  
});  

优势

  • 服务模块 ProductService 封装数据逻辑,可复用且易于测试。
  • 控制器通过依赖注入获取服务,避免硬编码依赖。

路由与多视图管理

结合 ngRoute 模块可实现单页应用(SPA)的路由功能:

<div ng-app="myApp" ng-controller="mainController">  
  <ul>  
    <li><a href="#/home">首页</a></li>  
    <li><a href="#/about">lt;/a></li>  
  </ul>  
  <div ng-view></div>  
</div>  

路由配置:

AngularJS示例有哪些?新手如何快速上手学习?

var app = angular.module('myApp', ['ngRoute']);  
app.config(function($routeProvider) {  
  $routeProvider  
    .when('/home', {  
      template: '<h1>首页内容</h1>'  
    })  
    .when('/about', {  
      template: '<h1>关于我们</h1>'  
    })  
    .otherwise({ redirectTo: '/home' });  
});  

说明

  • ng-view 作为视图容器,根据路由加载对应模板。
  • $routeProvider 定义路由规则,支持默认重定向。

AngularJS 通过数据绑定、模块化、路由等特性,为前端开发提供了结构化的解决方案,尽管现代框架如 Angular、React 已成为主流,但 AngularJS 的设计思想仍对前端工程化产生深远影响,掌握其核心概念有助于理解前端框架的演进逻辑。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/25121.html

(0)
上一篇2025年10月24日 02:30
下一篇 2025年10月23日 17:33

相关推荐

  • 服务器串口具体有什么用,又该如何连接配置使用?

    在当今高度网络化和虚拟化的数据中心里,服务器管理工具层出不穷,从图形化的远程控制台到功能强大的自动化运维平台,似乎已经覆盖了所有需求,在这些现代技术的背后,一个看似古老、低调的接口——服务器串口,依然扮演着不可或缺的角色,是系统管理员手中最可靠的“最后一道防线”,核心价值:带外管理的“生命线”服务器串口,通常也……

    2025年10月24日
    010
  • 玉溪服务器托管应该怎么选,需要注意哪些问题?

    在数字化浪潮席卷全球的今天,企业对稳定、高效、安全的IT基础设施需求日益迫切,服务器托管作为企业信息化建设的核心环节,其选址直接关系到业务的连续性、访问速度和运营成本,在这一背景下,玉溪托管服务器凭借其独特的优势,正逐渐成为众多企业,特别是面向南亚东南亚市场企业的战略新选择,玉溪托管服务器的核心优势玉溪托管服务……

    2025年10月23日
    020
  • Apache服务器启动失败怎么办?排查解决方法与常见原因详解

    当Apache服务器无法正常启动时,用户可能会遇到浏览器无法访问网站、服务无响应等问题,这种情况可能由多种原因引起,包括配置错误、端口冲突、权限问题或依赖组件缺失等,本文将系统性地分析Apache服务器启动失败的常见原因,并提供详细的排查步骤和解决方案,帮助用户快速定位并解决问题,检查错误日志定位问题根源Apa……

    2025年10月22日
    020
  • Apache2.4.6漏洞如何修复?有哪些影响?

    Apache作为全球使用最广泛的Web服务器软件,其安全性始终是企业和开发者关注的焦点,Apache 2.4.6版本中被曝出一个高危漏洞(CVE编号暂未公开,行业内暂称Apache246漏洞),该漏洞可能攻击者远程执行代码、获取服务器敏感信息甚至完全控制服务器,本文将从漏洞原理、影响范围、修复方案及防御措施等方……

    2025年10月21日
    030

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注