源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

模板视图和AngularJS之间冲突的解决方法

  • 时间:2021-03-01 11:22 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:模板视图和AngularJS之间冲突的解决方法
本文实例讲述了模板视图和AngularJS之间冲突的解决方法。分享给大家供大家参考,具体如下: [b]问题:[/b] 在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 之间的矛盾? [b]第一种解决方案:[/b]
<script>
 var usersPrefetch = [
  <?php foreach(users as user):?>
  {"name": "<?=$user->name?>", "email": "<?=$user->email?>"},
  <?php endforeach?>
 ];
</script>

我们将 php传过来的数据存储在变量里,然后再通过 $scope对其进行赋值,ok [b]第二种解决方案(推荐):[/b] 我们使用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程序设计有所帮助。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部