您的位置:首页 > Web前端 > AngularJS

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

2015-03-30 17:43 489 查看
问题:

在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/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: