位置: 编程技术 - 正文

浅谈Angular文字折叠展开组件的原理分析(angular ngshow)

编辑:rootadmin

推荐整理分享浅谈Angular文字折叠展开组件的原理分析(angular ngshow),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:angular width,angular ngshow,angular ngchange,angular的ngif,angular 文档,angular doc,angular语言,angular doc,内容如对您有帮助,希望把文章链接给更多的朋友!

自己写了个Angular的文字折叠组件,这种组件其实很多地方都能用到效果如下

展开后的效果

折叠后的效果

先放全部代码,使用的时候只需要把自己需要展现的文字{{designer.des}}替换成自己所在路由器所需要绑定的数据即可

下面我一句句的分析这个组件的思路

首先肯定是定义好Angular该组件化的模板和使用模式

EA为,使用元素和属性的方法都可以在DOM里面展现这个插件,既我可以这样 <textfold></textfold>也可以这样<div textfold="Wsscat"></div>的形式来复用该组件 后面我们使用link定义一个函数

浅谈Angular文字折叠展开组件的原理分析(angular ngshow)

这两个变量一个是此时折叠完后的高度(这个是在展开变成折叠的过程中不断发生变化的,最后折叠后就是等于minheight),一个文字完全展开时候获取的高度

这两句其实很重要的,当我们获取文字的高度时候,是必须要捕获文字的变化(文字完全渲染后的高度),所以我们用scope.$watch来捕获designer.des的变化,当data不为空,即文字已渲染后

再去执行回调函数textfold来获取当前文字的高度,暂时试过这种方法可以获取到文字渲染后的高度

如果顺序执行而不是回调执行

只会拿到span标签的默认高度而已

这里还可以添加个小技巧,增加一句scope.more();

这样就可以让它页面渲染完后先展开,然后再折叠,那么我们就在进来页面的时候默认是折叠的状态了,在程序里面,写这种效果,一般是先让它文字展开获取到高度再返回成折叠状态,来达到进来页面就是折叠的文字状态效果

var isExtend = true;这句是让下面的scope.more进入第一个分支折叠状态

这句是一句递归,其实就相当于实现jQuery的animate的文字框伸缩动画,只是这里用了一个递归来实现不断进来判断状态从而改变height值

然后通过改变scope.isMore改变它是查看更多…还是折叠

由于这里是用DOM操作

下面这里最好加多一句

来获取DOM的变化

其实大概思路就是很简单的,其他一些地方也是很容易理解~有什么好的方法欢迎推荐,或者文中有什么错漏或者不足还请多多留言告知,

标签: angular ngshow

本文链接地址:https://www.jiuchutong.com/biancheng/378889.html 转载请保留说明!

上一篇:vue 文件目录结构详解(vue3目录解析)

下一篇:浅谈vue-cli加载不到dev-server.js的解决办法(vue@cli)

  • 一般纳税人和小规模纳税人哪个合适
  • 税务师考试2023年考试时间
  • 出口退税中的免抵税额可以认为是交的税吗
  • 调整未分配利润影响所得税吗
  • 出口退免税备案
  • 业务人员差旅费为什么不计入投资性房地产成本
  • 农产品核定扣除范围
  • 套期保值账务处理出售被套期项目
  • 暂估发票到账出入库单要填吗
  • 交易性金融资产入账价值怎么计算
  • 定额备用金补付会计分录怎么写?
  • 发给职工的福利要交个税吗
  • 注册资金未到账需要缴纳印花税吗
  • 新车车牌照
  • 城市垃圾处理费怎么申报
  • 土地增值税的征税对象,是村集体
  • 个税纳税期数如何规定的 怎么选择
  • 简易计税视同销售如何处理?
  • 不动产登记房屋已竣工的材料
  • 会计准则规定的关联方
  • 不抵扣发票如何勾选
  • 信用担保对中小企业的作用
  • 期末留抵税额可以冲减欠税吗
  • 一年内到期的应付债券计入
  • 长期待摊费用2021
  • 会计跨年业务的处理
  • wordpress如何使用
  • 文件被占用无法删除
  • 搜索框无法搜索内容
  • PHP:Memcached::appendByKey()的用法_Memcached类
  • 租赁固定资产成本怎么算
  • php使用memcache
  • 股权转让所得怎么做账
  • nbscheduler是什么程序
  • kzip_main.exe是什么
  • 小程序开发一个多少钱啊
  • php上级目录
  • 深度强化学习-DQN算法原理与代码
  • tabstat命令怎么用
  • php数学
  • python replace 多个
  • python 函数 global
  • 投资收益收到的现金增加的原因
  • 汽车租赁属于经营租赁吗
  • 小规模差额征税的账务处理
  • 企业所得税期间费用明细表
  • 合伙人资本属于个人资本吗?
  • 企业转让固定资产发生的费用可扣除吗
  • 公司开业前期费用谁出
  • 股权质押和股权抵押有什么区别
  • 投资性房地产租金税率是多少
  • 企业会计准则基本准则
  • 存货总账根据什么填列
  • 工业企业的生产费用包括哪些
  • mysql的基本介绍
  • sqlserver连接到服务器
  • win2003r2企业版密钥
  • ubuntu18.04lts
  • windows命令提示符命令大全
  • macbook系统快捷键
  • windows英文版本
  • 电脑用户名怎么改
  • win10收不到20h2更新
  • win8快捷键设置在哪里设置
  • pavsrv50.exe - pavsrv50进程管理信息
  • win7文件后缀名不全显示
  • 解决Android Studio下载gradle慢
  • opengl顶点坐标纹理坐标关系
  • node js入门
  • angular1
  • vue请求数据再赋值data
  • 自定义图片制作软件
  • unable to instantiate decoder
  • EasyUI Pagination 分页的两种做法小结
  • 税务部门公务员报考条件
  • 税务局监察室主任职位说明书
  • 环保税新政策
  • 个人彩票收入属什么类别
  • 贵州省税务网上缴费平台
  • 加强监督管理工作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设