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

相关推荐

  • 服务器计算机显示了蓝色屏幕故障事件

    服务器计算机显示了蓝色屏幕故障事件服务器计算机作为企业信息系统的核心设备,其稳定运行直接关系到业务的连续性和数据的安全性,在实际使用中,服务器偶尔会出现“蓝色屏幕故障事件”(俗称“蓝屏”),即Windows操作系统因无法从错误中恢复而强制显示的蓝色错误界面,蓝屏故障通常由硬件问题、驱动程序冲突、系统文件损坏或软……

    2025年12月2日
    01210
  • 企业服务器岳阳,岳阳地区企业服务器选购指南与常见问题解答?

    企业服务器的选择与应用企业服务器概述企业服务器是企业在信息化建设中的重要组成部分,它承担着企业数据存储、处理、传输等核心任务,在岳阳地区,随着企业规模的不断扩大和业务需求的日益增长,企业服务器的重要性愈发凸显,岳阳企业服务器市场分析市场规模近年来,岳阳企业服务器市场规模逐年扩大,据相关数据显示,2019年岳阳企……

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

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

      2026年1月10日
      020
  • grunt如何合并js文件?配置任务与代码合并技巧详解

    在Web前端开发中,JavaScript(JS)作为核心交互语言,其加载性能直接影响用户体验,随着项目复杂度提升,多个JS模块的独立加载会引发多个HTTP请求,增加页面加载时间,Grunt(一个基于Node.js的自动化任务运行器)通过其强大的插件生态系统,为开发者提供了自动化JS合并的解决方案,本文将深入解析……

    2026年1月26日
    0610
  • 服务器设备故障排除时,如何快速定位并解决常见硬件问题?

    服务器设备故障排除是保障业务连续性的关键环节,需遵循系统化、标准化的流程,快速定位并解决问题,以下从故障分类、排查步骤、常见场景及预防措施四个维度展开说明,故障分类:明确问题性质服务器故障可分为硬件故障、软件故障、网络故障三类,硬件故障包括CPU、内存、硬盘、电源等物理部件损坏;软件故障涉及操作系统、驱动程序……

    2025年12月3日
    01710

发表回复

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