AngularJS第一个小例子

1774 查看

<!DOCTYPE html>   
<html ng-app>   
<head>   
<meta charset="utf-8">   
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">   
<title>Examples</title>   
<meta name="description" content="">   
<meta name="keywords" content="">   
<link href="" rel="stylesheet">   
<style type="text/css">   
    span{display: inline-block;min-width: 100px;}   
    input{width: 100px;}   
</style>   
</head>   
<body ng-Controller="demoController">   
    <h1>{{demotitle}}</h1>   
    <div>   
        <span>标题</span>   
        <span>数量</span>   
        <span>单价</span>   
        <span>总结</span>   
        <span>操作</span>   
    </div>   
    <div ng-repeat="item in items">   
        <span>{{item.title}}</span>   
        <input type="text" ng-model="item.quantity"/>   
        <span>{{item.price | currency}}</span>   
        <span>{{item.price * item.quantity | currency}}</span>   
        <button ng-click="remove($index)">remove</button>   
    </div>   
<script src="angular.min.js"></script>   
<script>   
function demoController($scope){   
    $scope.demotitle = "第一个小例子";   
    $scope.items = [   
        {title:'test1',quantity:0,price:2.2},   
        {title:'test2',quantity:1,price:1.5},   
        {title:'test3',quantity:0,price:3.3},   
        {title:'test4',quantity:2,price:4}   
    ];   
    $scope.remove = function(index){   
        $scope.items.splice(index,1);   
    }   

}   
</script>   
</body>   
</html>  

生成的页面如下。

这是《用AngularJS开发下一代Web应用》这本书里的一个例子,用来理解AngularJS的一些特性,MVC,其中输入框为Model,定义了ng-model后用来在输入框和item.quantity的值之间创建数据绑定关系,而{{}}这样的结构用来展示我们在controller中定义的值。

ng-repeat的意思是讲items的作用,不知道怎么说好,主要是用来循环提取items数组中每个属性的值然后添加到dom中。

button控件绑定的click事件用来移除当前行,ng-click在controller中定义,传入index的值用来达到移除的效果。

前边这段话写的乱七八糟的。仅当作一个记录吧。