Angularjs 与三方js插件配合使用,并通过模板动态解析angularjs 语法

简介: 在一个静态见面上做数据分析,由于前后端分离 前端使用Angularjs框架,后端使用RESTFUL,如图

在一个静态见面上做数据分析,由于前后端分离 前端使用Angularjs框架,后端使用RESTFUL,如图

171814_UTTq_152472.png

A:在分页上遇到要使用三方分页插件


laypage

其使用方法如下:


var laypage;
layui.use('laypage',function(){
    laypage = layui.laypage ;
});
laypage.render({
    elem: 'pageDetail' //分页容器的id
    ,count: page.count //总页数
    ,skin: '#41cac0' //自定义选中色值
    ,theme: '#41cac0'
    ,curr: page.page
    //,skip: true //开启跳页
    ,jump: function(obj, first){
        if(!first){
            $scope.pro(obj.curr);
        }
    }
});

三方插件直接在app.controller中使用是无效的


var app = angular.module('datas',[]).controller('DatasController',function($scope,$http){
    //这里初始化是无效的,laypage undifined
   //var laypage;
   //layui.use('laypage',function(){ laypage = layui.laypage ; }); 

} 
angular.bootstrap(document,["datas"]);

Angularjs 如何调用三方插件 laypage,实现思路是既然在内部初始化无效,则使用外部初始化,并设置全局变量


var laypage;
layui.use('laypage',function(){
    laypage = layui.laypage ;
});
//TODO 关键点是通过这里向Controller传值laypage
app.value('laypage',laypage);
angular.bootstrap(document,['datas']); 
这样就可以在Controller内部通过 laypage.render() 方法调用laypage插件
$scope.page = function(){
    var page = $scope.condition;
    laypage.render({
        elem: 'pageDetail' //分页容器的id
        ,count: page.count //总页数
        ,skin: '#41cac0' //自定义选中色值
        ,theme: '#41cac0'
        ,curr: page.page
        //,skip: true //开启跳页
        ,jump: function(obj, first){
            if(!first){
                $scope.pro(obj.curr);
            }
        }
    });
}

B 关于模板解析

1,模板内容包含angularjs语法


<script type="text/template" id="template">
    <div class="treeview-item">
        <i class="btn-expand" action="toggleExpand" tag="{{tageId}}" ng-click="getChildTemplate($event)"></i>
        <span class="label-name" action="detailItem">{{tageName}} </span>
    </div>
    __CONTENT__
</script>

2,动态Html语法
 
var result = $("#template").html();
//todo 替换template中的值 
$("#templateItems").html(result);

3以上写法,由于template中包含ng-click 语法,执行网页动态脚本添加的时候,是已经编译过的网页内容,Angularjs无法识别到ng-click,则无法调用对应的方法,修改代码如下


$("#templateItems").html($compile(result)($scope));

原文发布时间为:2018年03月20日
原文作者:  ReSky 

本文来源:开源中国 如需转载请联系原作者


目录
相关文章
|
8天前
|
JSON 前端开发 JavaScript
【JavaScript技术专栏】JavaScript异步编程:Promise、async/await解析
【4月更文挑战第30天】JavaScript中的异步编程通过Promise和async/await来解决回调地狱问题。Promise代表可能完成或拒绝的异步操作,有pending、fulfilled和rejected三种状态。它支持链式调用和Promise.all()、Promise.race()等方法。async/await是ES8引入的语法糖,允许异步代码以同步风格编写,提高可读性和可维护性。两者结合使用能更高效地处理非阻塞操作。
|
8天前
|
数据采集 JavaScript 前端开发
使用Go和JavaScript爬取股吧动态信息的完整指南
本文介绍了如何使用Go和JavaScript构建网络爬虫,从股吧网站抓取实时股市信息。通过设置代理服务器以应对反爬策略,利用`got`库执行JavaScript提取动态数据,如用户讨论和市场分析。示例代码展示了爬虫的实现过程,包括浏览器实例创建、代理配置、JavaScript执行及数据打印。此方法有助于投资者及时获取市场资讯,为决策提供支持。
使用Go和JavaScript爬取股吧动态信息的完整指南
|
8天前
|
SQL 缓存 JavaScript
深入解析JavaScript中的模板字符串
深入解析JavaScript中的模板字符串
16 1
|
8天前
|
JavaScript
js的插件
js的插件
15 1
|
8天前
|
设计模式 前端开发 JavaScript
AngularJS是一款由Google收购的JavaScript结构框架
【5月更文挑战第2天】AngularJS是Google收购的JavaScript框架,用于构建动态Web应用,基于MVC模式,强调模块化和双向数据绑定。它简化了视图与模型的同步,通过语义化标签和依赖注入提升开发效率。适用于复杂单页面应用(SPA),但不适合DOM操作密集型或性能要求极高的场景。
26 0
|
8天前
|
C++
【期末不挂科-C++考前速过系列P6】大二C++实验作业-模板(4道代码题)【解析,注释】
【期末不挂科-C++考前速过系列P6】大二C++实验作业-模板(4道代码题)【解析,注释】
【期末不挂科-C++考前速过系列P6】大二C++实验作业-模板(4道代码题)【解析,注释】
|
8天前
|
JavaScript 网络协议 数据处理
Node.js中的Buffer与Stream:深入解析与使用
【4月更文挑战第30天】本文深入解析了Node.js中的Buffer和Stream。Buffer是处理原始数据的全局对象,适用于TCP流和文件I/O,其大小在V8堆外分配。创建Buffer可通过`alloc`和`from`方法,它提供了读写、切片和转换等操作。Stream是处理流式数据的抽象接口,分为可读、可写、双工和转换四种类型,常用于处理大量数据而无需一次性加载到内存。通过监听事件和调用方法,如读取文件的可读流示例,可以实现高效的数据处理。理解和掌握Buffer及Stream能提升Node.js应用的性能。
|
8天前
项目管理工具计划模板解析:项目管理工具的双重功能与创建方法
本文介绍了项目计划模板的含义和重要性。项目计划模板是用于规划项目结构的可编辑文档,帮助团队明确任务、分配责任和管理时间。模板有助于跟踪项目进度、避免任务冲突,并简化会议安排。创建模板通常涉及选择合适的项目管理工具,如Zoho Projects或Microsoft Excel,然后分解任务、定义日期并持续调整。在Zoho Projects中,用户可以按步骤创建模板,包括命名、添加任务和设置相关细节。
21 0
|
8天前
|
JavaScript 前端开发 开发者
Node.js的包管理和npm工具深度解析
【4月更文挑战第30天】本文深入解析Node.js的包管理和npm工具。包管理促进代码复用和社区协作,包包含元数据描述文件`package.json`和入口文件。npm提供搜索、安装、发布等功能,通过命令行进行操作,如`install`、`search`、`uninstall`。npm支持版本控制、全局安装、脚本定义及私有仓库。理解和熟练运用npm能提升Node.js开发效率。
|
8天前
|
前端开发 JavaScript 数据安全/隐私保护
前端javascript的DOM对象操作技巧,全场景解析(二)
前端javascript的DOM对象操作技巧,全场景解析(二)

推荐镜像

更多