通过js代码来改变div的宽度

当做网页图片的切换时,有的做法是将两个div并排在一起,但是只能显示一个div的宽度,当要切换图片时将一个div的宽度从一个宽度值改为0,就实现了简单的图片替换了。
首先,我们将要更改宽度的div摆上来

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>测试</title>
    <style>
         #ddd{
            background-color: red;
         }
    </style>
</head>
<body>
    <div id= "ddd" style="width:800px;height:500px"></div>
    <button onClick="change();" type="button" class="slick-prev slick-arrow" >button</button>
</body>
</html>

一个背景颜色为红色的div,使用按钮来改变大小
然后我们需要加上一段js代码,来修改掉这个div的大小

<script>
function change() {
var mywidth=document.getElementById("ddd").clientWidth;
if(mywidth!="100")
{
ddd.style.width=(mywidth-700)+"px";
}else
{
ddd.style.width=(mywidth+700)+"px";
}
alert(mywidth.style.width);
}
</script>

改变高度同理,下面是测试完整代码:

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>测试</title>
    <style>
         #ddd{
            background-color: red;
         }
    </style>
	<script>
function change() {
var mywidth=document.getElementById("ddd").clientWidth;
if(mywidth!="100")
{
ddd.style.width=(mywidth-700)+"px";
}else
{
ddd.style.width=(mywidth+700)+"px";
}
alert(mywidth.style.width);
}
</script>
</head>
<body>
    <div id= "ddd" style="width:800px;height:500px"></div>
    <button onClick="change();" type="button" class="slick-prev slick-arrow" >button</button>
</body>
</html>
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 首先,你需要在 Vue 实例中定义一个计算属性,用于获取 div宽度。然后,你可以使用 Vue 的 `$watch` 函数来监听这个计算属性的变化。 例如: ``` <template> <div ref="myDiv">Some content</div> </template> <script> export default { data() { return { divWidth: 0 } }, computed: { divWidthComputed: { get() { return this.$refs.myDiv.offsetWidth } } }, mounted() { this.$watch('divWidthComputed', (newVal, oldVal) => { this.divWidth = newVal }) } } </script> ``` 在这个例子中,当 div宽度发生改变时,计算属性 `divWidthComputed` 的值也会相应地发生改变。$watch 函数会监听这个计算属性的值,并在其发生改变时执行回调函数,将新的值赋值给 `divWidth` 变量。 你也可以使用其他方法来监听 div宽度变化,例如使用 MutationObserver 或者 ResizeObserver 等。 ### 回答2: 要监听一个div宽度改变,可以使用Vue中的watch属性和$refs来实现。 首先,在div元素上添加一个ref属性,将其命名为"myDiv",如下所示: ``` <div ref="myDiv"></div> ``` 然后,在Vue组件的watch属性中添加一个监听器来监测该div宽度改变,如下所示: ``` watch: { myDivWidth: function(newWidth, oldWidth) { // 宽度改变时执行的代码 console.log("宽度改变:" + newWidth); } } ``` 在Vue组件的mounted钩子函数中,可以通过this.$refs来获取div元素的引用,并通过offsetWidth属性获取其当前的宽度,如下所示: ``` mounted() { this.$nextTick(() => { this.myDivWidth = this.$refs.myDiv.offsetWidth; }); } ``` 在上述代码中,通过mounted钩子函数和this.$nextTick方法,确保在组件初始化渲染完成后再获取div宽度,并将其赋值给myDivWidth变量。 一旦div宽度改变,watch监听器就会被触发,执行相应的代码。在上述代码中,我们将新宽度newWidth打印到控制台,你可以根据需要自行修改或扩展。 完成以上操作后,你就可以监听并响应div宽度改变了。 ### 回答3: 在Vue中,监听一个div宽度改变可以通过使用Vue的指令和监听器来实现。 首先,要确保需要监听宽度改变div有一个唯一的标识符或类名,以便能够在Vue中进行选择和操作。例如,我们给需要监听的div添加一个类名为"resize-div"。 然后,在Vue组件的生命周期钩子函数中,可以使用指令`v-once`和`v-resize`来监听div宽度改变。 具体步骤如下: 1. 在需要监听宽度改变div中添加类名"resize-div",如: ```html <div class="resize-div"></div> ``` 2. 在Vue组件的生命周期钩子函数`mounted`中,使用`querySelector`方法选择该div,并将其存储在一个变量中。 ```javascript mounted() { const resizeDiv = document.querySelector('.resize-div'); } ``` 3. 在Vue组件中的`mounted`钩子函数中,使用`ResizeObserver`监听resizeDiv宽度改变,并在回调函数中执行相应的操作。 ```javascript mounted() { const resizeDiv = document.querySelector('.resize-div'); const resizeObserver = new ResizeObserver((entries) => { // 获取最新的宽度 const width = entries[0].contentRect.width; // 执行相应的操作 // ... }); resizeObserver.observe(resizeDiv); } ``` 通过以上步骤,我们就可以监听到div宽度改变,并在回调函数中执行相应的操作。请注意,使用`ResizeObserver`需要确保浏览器支持该API,如果需要兼容性更好的解决方案,可以考虑使用第三方库,比如`ResizeSensor`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值