模板视图和AngularJS之间冲突的解决方法
2016-11-22 11:00
561 查看
问题:
在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 使用ng-repeat报错 [ngRepeat:dupes]
- AngularJS iframe跨域打开内容时报错误的解决办法
- AngularJS使用ng-inlude指令加载页面失败的原因与解决方法
- AngularJS中update两次出现$promise属性无法识别的解决方法
- AngularJS 中使用Swiper制作滚动图不能滑动的解决方法
- AngularJS实现在ng-Options加上index的解决方法
- AngularJS ng-repeat数组有重复值的解决方法
- AngularJS在IE下取数据总是缓存问题的解决方法
- AngularJS上拉加载问题解决方法
- AngularJS在IE8的不支持的解决方法
- AngularJS报错$apply already in progress的解决方法分析
相关文章推荐
- angularjs学习之四(解决模板视图和angularjs之间的冲突 )
- 手势和UI控件之间冲突的解决方法(比如UITapGesture和UIButton冲突,UIPanGesture和UISlider冲突)
- IOS 子视图touch,父视图Ges手势冲突问题解决方法
- 手势和UI控件之间冲突的解决方法(比如UITapGesture和UIButton冲突,UIPanGesture和UISlider冲突)
- 解决Django与AngularJS模板冲突的设置
- AngularJs和django的模板冲突问题解决
- 解决jinja2 模板和AngularJS分隔符冲突的方法
- ScrollView与ListView之间的滑动冲突解决方法
- Lambda FAQ_15.如何解决方法声明之间的冲突
- 无法解决 equal to 运算中 "Chinese_PRC_CI_AS" 和 "Chinese_PRC_90_CI_AI" 之间的排序规则冲突。的解决方法
- PHP针对常规模板引擎中与CSS/JSON冲突的解决方法
- 解决AngularJS和Django模板标签冲突问题
- PHP针对常规模板引擎中与CSS/JSON冲突的解决方法
- iOS的手势事件和可滚动视图(tableView、collectionView...)的触摸事件冲突的解决方法
- 无法解决 equal to 运算中 "Chinese_PRC_CI_AS" 和 "Chinese_PRC_90_CI_AI" 之间的排序规则冲突。的解决方法
- 解决AngularJS和Django模板标签冲突问题
- 手势和UI控件之间冲突的解决方法(比如UITapGesture和UIButton冲突,UIPanGesture和UISlider冲突)
- 手势和UI控件之间冲突的解决方法(比如UITapGesture和UIButton冲突,UIPanGesture和UISlider冲突)
- 关于手势之间的冲突的解决方法