uniapp动态修改元素节点样式详解

2022-04-15 0 1,227
目录
  • 一,通过style属性绑定来修改
    • html:
    • 对应的js:
    • 实现的效果:
  • 二,利用ref来获取dom元素节点
    • 代码:
    • 实现的效果:
  • 总结

    一,通过style属性绑定来修改

    第一步:肯定是需要获取元素节点

    在uniApp项目中没有windouw对象,所以通过document不能直接获取dom节点,vue的refs只对自定义组件有效,对uniapp中的标签不生效。

    查看uniapp官网有一个uni.createSelectorQuery() API;可以通过这个属性获取标签的样式,在通过动态绑定样式来修改;

    html:

    <button type="default" @click="handleFont">点击增大字体</button>
    <view class="weibo_box" id='index0' :style="{fontSize:vHeight + 'px'}">
    

    对应的js:

    data(){
    	return {
    		vHeight:22
    	}
    },
    
    
    handleFont(){
    	const that=this
    	uni.createSelectorQuery().select('#index0').boundingClientRect(function (data) { 
    	  console.log('元素信息0:',data)
    		  that.vHeight +=10
    	}).exec()
    }
    

    实现的效果:

    uniapp动态修改元素节点样式详解

    二,利用ref来获取dom元素节点

    代码:

    <button type="default" @click="handleFont">点击增大字体</button>
    <view class="weibo_box" id='index1' ref="mydom">
    	第二个
    </view>
    
    data(){
    	return {
    		vHeight:22
    	}
    },
    //部分代码不相关,省略
    
    handleFont(){
    	const that=this
    	that.$refs.mydom.$el.style.fontSize=that.vHeight+=1+'px'
    }
    

    实现的效果:

    uniapp动态修改元素节点样式详解

    总结

    本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注NICE源码的更多内容!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript uniapp动态修改元素节点样式详解 https://www.niceym.com/22913.html