12分布式电商项目 - AngularJS快速入门

简介: 12分布式电商项目 - AngularJS快速入门

1.表达式

<html>
  <head>
    <title>入门小 Demo-1</title>
    <script src="angular.min.js"></script>
  </head>
  <body ng-app>
    {{100+100}}
  </body>
</html>

执行结果如下:

表达式的写法是{{表达式 }}表达式可以是变量或是运算式

ng-app 指令 作用是告诉子元素一下的指令是归 angularJs 的,angularJs 会识别的

ng-app 指令 定义了 AngularJS 应用程序的根元素。

ng-app 指令 在网页加载完毕时会自动引导(自动初始化)应用程序。

2.双向绑定

<html>
  <head>
    <title>入门小 Demo-1 双向绑定</title>
    <script src="angular.min.js"></script>
  </head>
  <body ng-app>
    请输入你的姓名:<input ng-model="myname">
    <br>
    {{myname}},你好
  </body>
</html>

运行效果如下:

ng-model 指令用于绑定变量,这样用户在文本框输入的内容会绑定到变量上,而表达式可以实时地输出变量。

3.控制器

<html>
  <head>
    <title>入门小 Demo-3 初始化</title>
    <script src="angular.min.js"></script>
    <script type="text/javascript">
      //定义函数
      function helloController($scope) {
        $scope.greeting = {
        text : "hello"
        };
      }
    </script>
  </head>
  <body ng-app>
    <div ng-controller="helloController">
      <p>{{greeting.text}},angular!</p>
    </div>
  </body>
</html>

ng-controller 用于指定所使用的控制器

理解 $scope

$scope的使用贯穿整个 AngularJS App 应用,它与数据模型相关联,同时也是表达式执行的上下文.有了$scope 就在视图和控制器之间建立了一个通道,基于作用域视图在修改数据时会立刻更新 $scope,同样的$scope 发生改变时也会立刻重新渲染视图.

4.MVC模式

Angular 遵循软件工程的 MVC 模式,并鼓励展现,数据,和逻辑组件之间的松耦合,提高代码的复用性.angularJS 为后端减轻了很多业务压力,带来了更轻的 web 应用.

那么在 AngularJS 的应用中,怎么提现 mvc 设计模式的呢?下面来看以下代码展示 AngularJS 的

应用.

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>Insert title here</title>
    <script type="text/javascript" src="js/angular.min.js"/>     
    <script type="text/javascript">
    //定义函数
    function helloController($scope) {
        $scope.greeting = {
        text : "hello" //模型层
        };
    }
    </script>
  </head>
  <body ng-app>
    <div ng-controller="helloController"> //控制层
      <p>{{greeting.text}},angular!</p> //视图层
    </div>
  </body>
</html>

5.模块化设计

js 编程通常把 js 都放在全局环境中,那么这些变量函数,或者是对象都会产生在 window 对象下,会污染全局空间.为了更好管理 js,我们使用模块化的开发方式.

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>Insert title here</title>
    <script type="text/javascript" src="js/angular.min.js"/> 
    <script type="text/javascript">
      //定义一个叫oneModule名称的模块
      var myModule = angular.module('oneModule',[]);
      //使用模块调用方法
      myModule.controller('helloController',function($scope){
        $scope.greeting = function(){
          return "hello,angular!";
        }
      })
    </script>
  </head>
  <body ng-app="oneModule">
    <div ng-controller="helloController">
      <p>{{greeting()}},angular!</p>
    </div>
  </body>
</html>

6. 初始化指令

我们如果希望有些变量具有初始值,可以使用ng-init 指令来对变量初始化。

<html>
  <head>
    <title>入门小 Demo-3 初始化</title>
    <script src="angular.min.js"></script>
  </head>
  <body ng-app ng-init="myname='陈大海'">
    请输入你的姓名:<input ng-model="myname">
    <br>
    {{myname}},你好
  </body>
</html>

7.事件指令

<html>
  <head>
    <title>入门小 Demo-5 事件指令</title>
    <script src="angular.min.js"></script>
    <script>
      var app=angular.module('myApp',[]); //定义了一个叫 myApp 的模块
      //定义控制器
      app.controller('myController',function($scope){
        $scope.add=function(){
        $scope.z= parseInt($scope.x)+parseInt($scope.y);
      }
      });
    </script>
  </head>
  <body ng-app="myApp" ng-controller="myController">
    x:<input ng-model="x" >
    y:<input ng-model="y" >
    <button ng-click="add()">运算</button>
    结果:{{z}}
  </body>
</html>

运行结果:

ng-click 是最常用的单击事件指令,再点击时触发控制器的某个方法。

8.循环数组

<html>
  <head>
    <title>入门小 Demo-6 循环数据</title>
    <script src="angular.min.js"></script>
    <script>
      var app=angular.module('myApp',[]); //定义了一个叫 myApp 的模块
      //定义控制器
      app.controller('myController',function($scope){
        $scope.list= [100,192,203,434 ];//定义数组
      });
    </script>
  </head>
  <body ng-app="myApp" ng-controller="myController">
    <table>
      <tr ng-repeat="x in list">
      <td>{{x}}</td>
      </tr>
    </table>
  </body>
</html>

这里的 ng-repeat 指令用于循环数组变量。

运行结果如下:

9.循环对象数组

<html>
  <head>
    <title>入门小 Demo-7 循环对象数组</title>
    <script src="angular.min.js"></script>
    <script>
      var app=angular.module('myApp',[]); //定义了一个叫 myApp 的模块
      //定义控制器
      app.controller('myController',function($scope){
      $scope.list= [
      {name:'张三',shuxue:100,yuwen:93},
      {name:'李四',shuxue:88,yuwen:87},
      {name:'王五',shuxue:77,yuwen:56}
      ];//定义数组
      });
    </script>
  </head>
  <body ng-app="myApp" ng-controller="myController">
    <table>
      <tr>
        <td>姓名</td>
        <td>数学</td>
        <td>语文</td>
      </tr>
      <tr ng-repeat="entity in list">
        <td>{{entity.name}}</td>
        <td>{{entity.shuxue}}</td>
        <td>{{entity.yuwen}}</td>
      </tr>
    </table>
  </body>
</html>

运行结果如下:

10.内置服务

我们的数据一般都是从后端获取的,那么如何获取数据呢?我们一般使用内置服务$http 来实现。注意:以下代码需要在 tomcat 中运行。

<html>
  <head>
    <title>入门小 Demo-8 内置服务</title>
    <meta charset="utf-8" />
    <script src="angular.min.js"></script>
    <script>
      var app=angular.module('myApp',[]); //定义了一个叫 myApp 的模块
      //定义控制器
      app.controller('myController',function($scope,$http){
      $scope.findAll=function(){
        $http.get('data.json').success(
          function(response){
            $scope.list=response;
          }
        );
      }
    });
    </script>
  </head>
  <body ng-app="myApp" ng-controller="myController" ng-init="findAll()">
    <table>
      <tr>
        <td>姓名</td>
        <td>数学</td>
        <td>语文</td>
      </tr>
      <tr ng-repeat="entity in list">
        <td>{{entity.name}}</td>
        <td>{{entity.shuxue}}</td>
        <td>{{entity.yuwen}}</td>
      </tr>
    </table>
  </body>
</html>

建立文件 data.json:

[
  {"name":"张三","shuxue":100,"yuwen":93},
  {"name":"李四","shuxue":88,"yuwen":87},
  {"name":"王五","shuxue":77,"yuwen":56},
  {"name":"赵六","shuxue":67,"yuwen":86}
]


目录
相关文章
|
8月前
|
NoSQL 调度 Redis
19- 你的项目中哪里用到了分布式锁
在一个项目中,为解决集群环境下SpringTask定时任务的重复执行问题,采用了Redis实现分布式锁来管理任务调度,防止资源浪费。后来因任务量和执行规则增加,以及单节点效率限制,系统改用XXL-JOB,分布式锁不再使用。
79 2
|
4月前
|
NoSQL Java Redis
面试官:项目中如何实现分布式锁?
面试官:项目中如何实现分布式锁?
109 6
面试官:项目中如何实现分布式锁?
|
5月前
|
资源调度 Java 调度
项目环境测试问题之Schedulerx2.0通过分布式分片任务解决单机计算瓶颈如何解决
项目环境测试问题之Schedulerx2.0通过分布式分片任务解决单机计算瓶颈如何解决
项目环境测试问题之Schedulerx2.0通过分布式分片任务解决单机计算瓶颈如何解决
|
5月前
|
存储 缓存 开发框架
看看 Asp.net core Webapi 项目如何优雅地使用分布式缓存
看看 Asp.net core Webapi 项目如何优雅地使用分布式缓存
|
6月前
|
SQL NoSQL Java
如何在Java项目中实现分布式锁
如何在Java项目中实现分布式锁
|
6月前
|
消息中间件 Java 中间件
如何在Java项目中实现分布式事务管理
如何在Java项目中实现分布式事务管理
|
8月前
|
SQL 监控 关系型数据库
TiDB 分布式数据库快速入门详解
这些示例展示了TiDB的一些基本操作。实际使用时,你可能需要根据具体的业务需求和环境进行调整和优化。
564 4
|
8月前
|
XML NoSQL Java
Java单体项目和分布式项目中的锁
Java单体项目和分布式项目中的锁 Java单体项目和分布式项目中的锁
99 2
|
3月前
|
NoSQL Java Redis
太惨痛: Redis 分布式锁 5个大坑,又大又深, 如何才能 避开 ?
Redis分布式锁在高并发场景下是重要的技术手段,但其实现过程中常遇到五大深坑:**原子性问题**、**连接耗尽问题**、**锁过期问题**、**锁失效问题**以及**锁分段问题**。这些问题不仅影响系统的稳定性和性能,还可能导致数据不一致。尼恩在实际项目中总结了这些坑,并提供了详细的解决方案,包括使用Lua脚本保证原子性、设置合理的锁过期时间和使用看门狗机制、以及通过锁分段提升性能。这些经验和技巧对面试和实际开发都有很大帮助,值得深入学习和实践。
太惨痛: Redis 分布式锁 5个大坑,又大又深, 如何才能 避开 ?
|
1月前
|
存储 NoSQL Java
使用lock4j-redis-template-spring-boot-starter实现redis分布式锁
通过使用 `lock4j-redis-template-spring-boot-starter`,我们可以轻松实现 Redis 分布式锁,从而解决分布式系统中多个实例并发访问共享资源的问题。合理配置和使用分布式锁,可以有效提高系统的稳定性和数据的一致性。希望本文对你在实际项目中使用 Redis 分布式锁有所帮助。
104 5