AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > JavaScript

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

51自学网 http://www.wanshiok.com
模板,视图,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,冲突,解决方法  
上一篇:javascript入门之string对象【新手必看】  下一篇:js入门之Function函数的使用方法【新手必看】