This article gives you a detailed analysis of how Angular2 integrates other plug-ins. Friends who are interested can learn from it.
Preface: Nowadays, when many friends come into contact with Angular2, they will inevitably use some other third-party plug-ins, and these plug-ins may be based on jQuery, and there is no corresponding angular2 version, here I will explain how to integrate the third-party jQuery plug-in in this case. We take Angular2's integration of zTree as an example to illustrate the integration ideas and process.
zTree official website: http://www.treejs.cn/v3/main.php#_zTreeInfo
1. Generally when I want to integrate a plug-in like zTree , I will go directly to zTree’s online examples first, such as this example:
https://github.com/zTree/zTree_v3/blob/master/demo/cn/super/metro.html
The rendering is like this:
2. After seeing this effect, let’s look at the code of this example: The key code is here:
$(document).ready(function(){ $.fn.zTree.init($("#treeDemo"), setting, zNodes); });
JQuery is used in this code, right? If we want to integrate zTree, we must first introduce jQuery. So let’s not worry about how to integrate zTree. Let’s first solve the problem of how to introduce jQuery:
3. Introduce jQuery into the angular2 project. Of course, you can skip it if the plug-in you use does not depend on jQuery. This step, but generally third-party plug-ins rely on it, right. Introducing jQuery is relatively simple. Just introduce it in the index.html file:
"After this, we can test whether zTree is introduced normally. We add the following code to the ngOnInit method in the demo.component.ts file: "console.log($.fn. zTree);" Check the console and you will find the following output:![Enter picture description](https://static.oschina.net/uploads/img/201703/26204017_4TLk.png "Enter picture title here") in the output From the content, we can see that there is an init method used by zTree to initialize, so that we can actually write a zTree example.
5.zTree example
We check zTree's When you initialize the code, you will find that it requires 3 parameters. The first parameter is a jQuery object, and the second parameter is the zTree configuration object. For details, you can check the official documentation of zTree to see what parameters can be set (http:/ /www.treejs.cn/v3/api.php), the third parameter is used to generate the data of the zTree node.
Here we directly use the demo code in zTree and copy it directly to demo.component.ts In the file:
import { Component, OnInit } from '@angular/core'; declare var $ : any; @Component({ selector: 'app-demo', templateUrl: './demo.component.html', styleUrls: ['./demo.component.css'] }) export class DemoComponent implements OnInit { setting = { data: { simpleData: { enable: true } } }; zNodes = [ { id: 1, pId: 0, name: "父节点1 - 展开", open: true }, { id: 11, pId: 1, name: "父节点11 - 折叠" }, { id: 111, pId: 11, name: "叶子节点111" }, { id: 112, pId: 11, name: "叶子节点112" }, { id: 113, pId: 11, name: "叶子节点113" }, { id: 114, pId: 11, name: "叶子节点114" }, { id: 12, pId: 1, name: "父节点12 - 折叠" }, { id: 121, pId: 12, name: "叶子节点121" }, { id: 122, pId: 12, name: "叶子节点122" }, { id: 123, pId: 12, name: "叶子节点123" }, { id: 124, pId: 12, name: "叶子节点124" }, { id: 13, pId: 1, name: "父节点13 - 没有子节点", isParent: true }, { id: 2, pId: 0, name: "父节点2 - 折叠" }, { id: 21, pId: 2, name: "父节点21 - 展开", open: true }, { id: 211, pId: 21, name: "叶子节点211" }, { id: 212, pId: 21, name: "叶子节点212" }, { id: 213, pId: 21, name: "叶子节点213" }, { id: 214, pId: 21, name: "叶子节点214" }, { id: 22, pId: 2, name: "父节点22 - 折叠" }, { id: 221, pId: 22, name: "叶子节点221" }, { id: 222, pId: 22, name: "叶子节点222" }, { id: 223, pId: 22, name: "叶子节点223" }, { id: 224, pId: 22, name: "叶子节点224" }, { id: 23, pId: 2, name: "父节点23 - 折叠" }, { id: 231, pId: 23, name: "叶子节点231" }, { id: 232, pId: 23, name: "叶子节点232" }, { id: 233, pId: 23, name: "叶子节点233" }, { id: 234, pId: 23, name: "叶子节点234" }, { id: 3, pId: 0, name: "父节点3 - 没有子节点", isParent: true } ]; constructor() { } ngOnInit() { $.fn.zTree($("#ztree"),this.setting,this.zNodes); } }
Look at the above code, $.fn.zTree($("#ztree"),this.setting,this.zNodes);Here we use jQuery's id selector, then We need to add an ul element with the id of ztree in the template file demo.component.html
<ul id="ztree"><ul>
As for why it is ul, you can see the zTree documentation. Of course, you can also try other elements to see if it works. Implementation.
The above is what I compiled for everyone. I hope it will be helpful to everyone in the future.
Related articles:
How to use js to invoke App in WeChat ?
How to use the http module in node.js
What are the Javascript debugging commands?
Detailed interpretation of the file system and stream in nodeJs
What are the application scenarios of child processes in Node.js
About the child_process module in node (detailed tutorial)
The above is the detailed content of How to integrate plug-ins using Angular2 (detailed tutorial). For more information, please follow other related articles on the PHP Chinese website!