angularjs学习之四(解决模板视图和angularjs之间的冲突 )

问题:在php的mvc视图中,我们需要在加载的过程中传递一些数据给模板:如:

//这里是某个 controller $data['users'] = {something from databases};$this->load->view('home/index',$data);//这里是对应的视图<div ng-controller="loadData"><ul><!–1. 初始化的时候我们需要使用下面这句–><?php foreach(users as user):?><li><?=$user->name?>:<?=$user->email?><li><?php endforeach?><!–2. 但是结束后 我们需要使用这句 通过ajax 更新 –><li ng-repeat="user in users">{{user.name}}:{{user.email}}</li></ul></div>

那么现在问题来了 如何处理 1 和 2 之间的矛盾?

第一种解决方案:

<script> var usersPrefetch = [<?php foreach(users as user):?>{"name": "<?=$user->name?>", "email": "<?=$user->email?>"},<?php endforeach?> ];</script>我们将 php传过来的数据存储在变量里,然后再通过$scope对其进行赋值,ok

第二种解决方案(推荐):

我们使用ng-if属性解决我们的问题,,对于users未定义时调用php数据ajax传递完成后使用我们的数据并定义 $scope.users

<ul ng-if="!users"> <?php foreach(users as user):?> <li><?=$user->name?>:<?=$user->email?><li> <?php endforeach?></ul><ul ng-if="users"> <li ng-repeat="user in users">{{user.name}}:{{user.email}}</li></ul>demo演示地址:https://jsfiddle.net/mser49aq/1/

就是去旅行。牵着彼此的手,

angularjs学习之四(解决模板视图和angularjs之间的冲突 )

相关文章:

你感兴趣的文章:

标签云: