以及ajax以及angularjs 动态模板加载并进行渲染
Posted rongfengliang-荣锋亮
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了以及ajax以及angularjs 动态模板加载并进行渲染相关的知识,希望对你有一定的参考价值。
1. 源码
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script type="text/javascript" src="js/jquery-1.11.1.min.js"></script> <script type="text/javascript" src="director-master/build/director.js"></script> <script type="text/javascript" src="angular/angular.js"></script> <script> /// 定义模块 var login=angular.module("mylogin",[]); login.factory("dalongapp",function(){ return { appname:"dalong demo", appurl:"http://www.baidu.com" }; }); /// 此处注入模块 var myapp=angular.module("YYIMApp",["mylogin"]); myapp.run(function($rootScope){ alert("app is running") $rootScope.dalongappdemo={ dalonginfo:"dalong demo", daongage:33 }; }); /// 此处暴露共享的方法 myapp.controller("IMctrl",function($scope,dalongapp,$rootScope,$compile){ $scope.username={ appurl:"www.baidu.com" }; $scope.onclickdemo=function(){ console.log(dalongapp); alert($scope.username.appurl+dalongapp.appname+$rootScope.dalongappdemo.daongage); }; $rootScope.compileservice=function(ele,scope){ return $compile(ele)(scope); } $rootScope.safeApply=function(scope){ scope.$apply(); } }); </script> <script> /// 此处手工启动应用 angular.element("#dalongdemo").ready(function(){ angular.bootstrap(document.getElementById("dalongdemo"),["YYIMApp"]); }) </script> <script> function mess() { var content=$("#content"); var content2=$("#content2"); content.empty(); content2.empty(); first(); second(); } function first() { $.get("myapp.htm",function(data){ var html=data; var content=$("#content"); var content2=$("#content2"); var el=$(data); console.info("appappend el"); console.log(el); console.log(html); //content.append(html); console.log(angular); var appdalong=angular.element("#content"); console.log(appdalong) var scope= angular.element(document.getElementById("dalongdemo")).scope(); console.info("scope"); console.log(scope); /// 动态编译模板并进行数据加载 var appinfo= scope.$parent.compileservice(el,scope) content.append(appinfo); scope.$parent.safeApply(scope); console.log(appinfo); console.log(angular.element(document.getElementById("dalongdemo"))) // //angular.element("#YYIMApp").ready(function(){ // // angular.bootstrap(document.getElementById("YYIMApp"),["YYIMApp"]); // // }) }); } function second() { $.get("myapp1.htm",function(data){ var html=data; var content=$("#content"); var content2=$("#content2"); console.log(html); content2.append(html); // angular.element("#YYIMApp2").ready(function(){ // // angular.bootstrap(document.getElementById("YYIMApp2"),["YYIMApp"]); // // }) }); } function myappdemo() { var content=$("#content"); var content2=$("#content2"); content.empty(); content2.empty(); content.append(‘<p>dalong demo</p>‘) } var routes = { ‘/message‘: mess, ‘/appdemo‘:myappdemo }; var router = Router(routes); router.init(); </script> </head> <body> <h1>dalong demo</h1> <a href="#message">message</a> <br> <a href="#appdemo">myappdemo</a> <h1>first</h1> <div id="dalongdemo" ng-controller="IMctrl"> <h1>{{dalongappdemo.dalonginfo}}</h1> <div id="content"> </div> <h1>second</h1> <div id="content2"> </div> </div> </body> </html>
2. ajax 请求的模板片段文件:
<div id="YYIMApp"> <div ng-controller="IMctrl"> <h1 ng-bind="username.appurl">{{username.appurl}}</h1> <button ng-click="onclickdemo()">clickdemo</button> </div> </div>
原理解析:
主要是通过JavaScript 与angularjs 互调用并使用$compile 服务进行数据的动态渲染并添加DOM元素
价值:
可以方便的进行第三方框架与angularjs 的集成,如果使用ng-app 等指令可能会便捷性比较小。
以上是关于以及ajax以及angularjs 动态模板加载并进行渲染的主要内容,如果未能解决你的问题,请参考以下文章
如何在AngularJS中通过AJAX加载数据后重新初始化数据表?