angularjs学习之四(解决模板视图和angularjs之间的冲突 )
2015-03-30 17:43
489 查看
问题:
在php的mvc视图中,我们需要在加载的过程中
传递一些数据给模板:
如:
那么现在问题来了 如何处理 1 和 2 之间的矛盾?
第一种解决方案:
我们将 php传过来的数据存储在变量里,然后再通过
$scope对其进行赋值,ok
第二种解决方案(推荐):
我们使用ng-if属性解决我们的问题,对于users未定义时调用php数据
ajax传递完成后使用我们的数据并定义 $scope.users
demo演示地址:https://jsfiddle.net/mser49aq/1/
在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和Django模板标签冲突问题
- 解决AngularJS和Django模板标签冲突问题
- AngularJS学习之ng-if嵌套ng-model变量冲突解决
- 解决Django与AngularJS模板冲突的设置
- AngularJs和django的模板冲突问题解决
- 数据结构与算法学习之路:简单的哈希表实现(链地址法解决冲突)
- Spring MVC 3学习笔记+教程(二)在controller和视图之间传递参数
- Discuz!自制模板带jquery时与discuz本身冲突解决办法
- 深度学习解决多视图非线性数据特征融合问题
- 父视图的UITapGestureRecognizer和子视图UICollectionView的cell点击冲突解决办法
- android 自定义ScrollView实现反弹效果(以及解决和ListView之间的冲突)
- SVN的学习之路六(冲突解决)
- iOS 解决cell滑动删除和scrollView左右滑动之间的冲突
- sql:无法解决 equal to 操作中 "Chinese_PRC_CI_AS" 和 "Chinese_Taiwan_Stroke_CI_AS" 之间的排序规则冲突。
- 解决AngularJS中ng-repeat不更新视图的问题
- AngularJS学习---更多模板(More Templating) step 8
- 黄聪:Discuz自制模板带jquery时与discuz本身冲突解决办法
- 解决weblogic和asix之间冲突
- MyBatis入门学习教程 解决字段名与实体类属性名不相同的冲突