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月24日 02:49

相关推荐

  • 阜新AR增强现实产品采购批发市场现状及趋势探讨?

    阜新AR增强现实:采购批发全攻略AR增强现实简介增强现实(Augmented Reality,简称AR)是一种将虚拟信息叠加到现实世界中的技术,通过AR技术,用户可以看到真实世界与虚拟信息的结合,为各行各业带来了全新的体验和应用,阜新市作为我国东北地区的重要城市,近年来在AR增强现实领域也取得了显著的发展,阜新……

    2026年1月26日
    01390
  • 服务器购买配置怎么选才合适?

    服务器购买配置的选择在数字化时代,服务器作为企业业务运行的“核心引擎”,其配置选择直接影响系统稳定性、性能扩展成本及未来业务适配能力,面对市场上琳琅满目的硬件参数与品牌型号,如何科学选择服务器配置,需结合业务需求、技术架构及预算约束综合考量,以下从核心组件、应用场景、扩展性及成本四个维度,解析服务器配置的关键选……

    2025年11月21日
    02390
  • 负载均衡节点重启是否会影响业务连续性和用户体验?

    负载均衡节点的重启是分布式系统运维中的关键操作,直接影响业务连续性与用户体验,这一操作看似简单,实则涉及流量调度、会话保持、健康检查机制等多重技术细节的精密配合,需要运维团队具备深厚的架构理解与丰富的实战经验,从架构层面审视,负载均衡节点的重启策略主要分为平滑重启与强制重启两种模式,平滑重启通过双机热备或集群冗……

    2026年2月12日
    01020
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • 俄罗斯GPU服务器怎么样?RTX 4090深度学习测评如何?

    HostDime推出的这款俄罗斯节点RTX 4090 GPU服务器,以999元/月的价格切入市场,确实是当前深度学习算力租赁领域中极具性价比的选择,对于预算有限但追求高性能单卡算力的个人开发者、AI绘画创作者以及进行中小规模大模型微调的研究团队而言,这款产品不仅解决了硬件采购成本高昂的痛点,更在算力性能与租赁成……

    2026年2月23日
    05132

发表回复

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