当前位置 : 主页 > 网络编程 > JavaScript >

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

来源:互联网 收集:自由互联 发布时间:2022-04-19
目录 一,通过style属性绑定来修改 html: 对应的js: 实现的效果: 二,利用ref来获取dom元素节点 代码: 实现的效果: 总结 一,通过style属性绑定来修改 第一步:肯定是需要获取元素节点
目录
  • 一,通过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()
    }
    

    实现的效果:

    在这里插入图片描述

    二,利用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'
    }
    

    实现的效果:

    在这里插入图片描述

    总结

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

    上一篇:JS基于VUE组件实现城市列表效果
    下一篇:没有了
    网友评论