Angular 组件升级实战:将项目中的ng2-tree组件替换成ngx-tree

本文讨论了面向对象编程(如Java、C++和C#)与原型编程(如JavaScript)的区别,以及在项目中如何使用ng2-tree和ngx-treeview来展示编程语言的树状结构。文章还涉及了如何调整复选框样式以适应单选模式,并提到了前端开发者的学习资源和注意事项。
摘要由CSDN通过智能技术生成

value: ‘Object-oriented programming’,

children: [

{value: ‘Java’},

{value: ‘C++’},

{value: ‘C#’}

]

},

{

value: ‘Prototype-based programming’,

children: [

{value: ‘JavaScript’},

{value: ‘CoffeeScript’},

{value: ‘Lua’}

]

}

]

}

每个节点都有value和children属性(可选)。value是该节点的值,children表示该节点是否有子节点,是个数组。

该树结构的父子/兄弟关系其实非常容易看出来。

接口:TreeModel Interface

interface TreeModel {

value: string | RenamableNode;

id: string | number;

children?: Array;

loadChildren?: ChildrenLoadingFunction;

settings?: TreeModelSettings;

}

结合一下TreeModel接口,树的结构大概是下面这样子:

public tree: TreeModel = {

value: ‘Programming languages by programming paradigm’,

id: 1,

children: [

{

value: ‘Object-oriented programming’,

id: 2,

children: [

{value: ‘Java’, id: 3},

{value: ‘C++’, id: 4},

{value: ‘C#’, id 5},

]

},

{

value: ‘Prototype-based programming’,

id: 6,

children: [

{value: ‘JavaScript’, id: 7},

{value: ‘CoffeeScript’, id: 8},

{value: ‘Lua’, id: 9},

]

}

]

};

在我所做的那一Part里面,ng2-tree树结构节点的主要三个属性是

  • value

  • id

  • children

使用ng2-tree:

<tree

[tree]=“tree”

[settings]=“settings”

(nodeRemoved)=“handleRemoved($event)”

(nodeRenamed)=“handleRenamed($event)”

(nodeSelected)=“handleSelected($event)”

(nodeMoved)=“handleMoved($event)”

(nodeCreated)=“handleCreated($event)”

(nodeExpanded)=“handleExpanded($event)”

(nodeCollapsed)=“handleCollapsed($event)”

(loadNextLevel)=“handleNextLevel($event)”>

tree,settings,nodeSelected和nodeExpanded等这些,就是可以在ng2-tree的template模板里面使用的一些API吧。

demo实例:

<tree [tree]=“treeNodes” [settings]=“treeSettings” (nodeSelected)=“showNgTwoTree( e v e n t ) " ( n o d e E x p a n d e d ) = " o n N o d e E x p a n d e d ( event)" (nodeExpanded)="onNodeExpanded( event)"(nodeExpanded)="onNodeExpanded(event)” (nodeCollapsed)=“onNodeCollapsed($event)”>

nodeSelected等这些的使用,具体看项目的功能需求。

初识ngx-treeview

=============================================================================

其实ngx-treeview也和ng2-tree差不多,换汤不换药。使用上仅是在一些特性,功能,属性这些作了一些文章。

详细的介绍都可以去其npm上查看浏览。

先看看ngx-treeview的结构是怎么样:

const category = new TreeviewItem({

text: “IT”,

value: 9,

children: [

{

text: “Programming”,

value: 91,

children: [

{

text: “Frontend”,

value: 911,

children: [

{ text: “Angular 1”, value: 9111 },

{ text: “Angular 2”, value: 9112 },

{ text: “ReactJS”, value: 9113 },

],

},

{

text: “Backend”,

value: 912,

children: [

{ text: “C#”, value: 9121 },

{ text: “Java”, value: 9122 },

{ text: “Python”, value: 9123, checked: false },

],

},

],

},

{

text: “Networking”,

value: 92,

children: [

{ text: “Internet”, value: 921 },

{ text: “Security”, value: 922 },

],

},

],

});

每个node主要有三个属性

  • text

  • value

  • children

具体是什么就不多说了~

也可以单独创建一个节点,再把这个节点添加到某一节点的children数组里面:

const vegetableCategory = new TreeviewItem({

text: “Vegetable”,

value: 2,

children: [

{ text: “Salad”, value: 21 },

{ text: “Potato”, value: 22 },

],

});

vegetableCategory.children.push(

new TreeviewItem({ text: “Mushroom”, value: 23, checked: false })

);

再看看treeviewItem都有些什么东西可以用:

在这里插入图片描述

demo示例:

config = TreeviewConfig.create({

hasAllCheckBox:true,

hasFilter:true,

hasCollapseExpand:true,

maxHeight:400;

})

<ngx-treeview class=“ngx-tree” [items]=‘items’ [config]=“config” (selectedChange)=“onSelectedChange( e v e n t ) " ( f i l t e r C h a n g e ) = " o n F i l t e r C h a n g e ( event)" (filterChange)="onFilterChange( event)"(filterChange)="onFilterChange(event)”>

简单的使用就是这样子:

  • 数据放到items里;config是ngx-treeview的配置,可以自行配置其是否有checkbox,是否有过滤查找,最大高度是多少等等

  • 主要使用的属性,text,value,children,checked,collapsed和disabled。分别对应文本,值,子节点,是否被点击,是否展开,是否禁用。

改造之路 ①(坑)

========================================================================

如果要改造的话,就面临几个需要解决的问题:

  • 要把ngx-treeview的原生样式改得与原本的样式一样,需要统一。

  • ngx-treeview本质是个复选框checkbox。然而使用树形菜单,当然是要单选框radio。总不可能:点击nodeOne,响应nodeOne的内容;再点击nodeTwo,响应nodeOne和nodeTwo的内容吧!所以问题是怎么把checkbox改成radio.

  • ngx-treeview一开始Show出来后,每个node都是被选中的(总不能刚显示出菜单,就响应所有的内容吧!我压根都没有选过哪个菜单!)。所以要限制其一开始都是不选中的状态

修改样式


自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

基础知识是前端一面必问的,如果你在基础知识这一块翻车了,就算你框架玩的再6,webpack、git、node学习的再好也无济于事,因为对方就不会再给你展示的机会,千万不要因为基础错过了自己心怡的公司。前端的基础知识杂且多,并不是理解就ok了,有些是真的要去记。当然了我们是牛x的前端工程师,每天像背英语单词一样去背知识点就没必要了,只要平时工作中多注意总结,面试前端刷下题目就可以了。

什么?你问面试题资料在哪里,这不是就在你眼前吗(滑稽

RDTiDa-1712083723628)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

基础知识是前端一面必问的,如果你在基础知识这一块翻车了,就算你框架玩的再6,webpack、git、node学习的再好也无济于事,因为对方就不会再给你展示的机会,千万不要因为基础错过了自己心怡的公司。前端的基础知识杂且多,并不是理解就ok了,有些是真的要去记。当然了我们是牛x的前端工程师,每天像背英语单词一样去背知识点就没必要了,只要平时工作中多注意总结,面试前端刷下题目就可以了。

什么?你问面试题资料在哪里,这不是就在你眼前吗(滑稽

资料领取方式:戳这里免费领取

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值