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/
















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值