模板视图和AngularJS之间冲突的解决方法
本文实例讲述了模板视图和AngularJS之间冲突的解决方法。分享给大家供大家参考,具体如下:
问题:
在php的mvc视图中,我们需要在加载的过程中
传递一些数据给模板:
如:
这里是某个controller
$data['users']={somethingfromdatabases};
$this->load->view('home/index',$data);
这里是对应的视图
<divng-controller="loadData">
<ul>
<!--1.初始化的时候我们需要使用下面这句-->
<?phpforeach(usersasuser):?>
<li><?=$user->name?>:<?=$user->email?><li>
<?phpendforeach?>
<!--2.但是结束后我们需要使用这句通过ajax更新-->
<ling-repeat="userinusers">{{user.name}}:{{user.email}}</li>
</ul>
</div>
那么现在问题来了如何处理1和2之间的矛盾?
第一种解决方案:
<script>
varusersPrefetch=[
<?phpforeach(usersasuser):?>
{"name":"<?=$user->name?>","email":"<?=$user->email?>"},
<?phpendforeach?>
];
</script>
我们将php传过来的数据存储在变量里,然后再通过
$scope对其进行赋值,ok
第二种解决方案(推荐):
我们使用ng-if属性解决我们的问题,对于users未定义时调用php数据
ajax传递完成后使用我们的数据并定义$scope.users
<ulng-if="!users">
<?phpforeach(usersasuser):?>
<li><?=$user->name?>:<?=$user->email?><li>
<?phpendforeach?>
</ul>
<ulng-if="users">
<ling-repeat="userinusers">{{user.name}}:{{user.email}}</li>
</ul>
demo演示地址:https://jsfiddle.net/mser49aq/1/
希望本文所述对大家AngularJS程序设计有所帮助。