element-plus中的collapse组件中的箭头图标移到左边问题解决(改进版)

element-plus中的collapse组件中的箭头图标移到左边问题解决(改进版)_第1张图片 

 

1、问题BUG

这个问题虽然解决了,但是依旧有一些bug,首先我们来看一下,他的样式变成了什么样的。

下面就是我们修改后的样子了,但是对于我们的需求来说,左边的箭头样式是没问题了

 可是到了箭头到了右边却变成了下面的样子,箭头本应该显示在红色的框框里面,但是并没有若我们预期想的一样,这显然和我们的需求不符合

 经过修改发现,造成这种现象的原因是我们把小箭头的margin值写死了,所以他的样式才会这样呈现,下面来看我们修改的过程

首先我们可以看到他是有一个非常大的margin-left的值

经过查看我们可以知道,他的值源于margin:0 8px 0 auto

element-plus中的collapse组件中的箭头图标移到左边问题解决(改进版)_第2张图片

2、BUG原因

好在我们可以动态添加他的属性,下面我么回到代码当中 

 
      
      
    

这是我们自己封装的一个组件,arrowPosition这个属性是我们用来控制箭头的左右位置的right表示箭头偏向右边,left表示箭头偏向左边

element-plus中的collapse组件中的箭头图标移到左边问题解决(改进版)_第3张图片

 我们可以看到,这个默认值就是right

element-plus中的collapse组件中的箭头图标移到左边问题解决(改进版)_第4张图片

3、解决办法 

下面就是解决办法

onMounted(() => {
  if (props.arrowPosition === "left") {
    const itemList = document.getElementsByClassName("el-collapse-item__header");
    console.log(itemList);
    Array.from(itemList).forEach((item: any) => {
      item.appendChild(item.lastElementChild);
      item.appendChild(item.firstElementChild);
      const icon = document.getElementsByClassName("el-collapse-item__arrow");
      Array.from(icon).forEach((item: any) => {
        item.style.marginLeft="5px"
      });
    });
  }
});

解析:

根据props.arrowPosition的值为"left",通过getElementsByClassName方法获取了带有类名el-collapse-item__header的元素集合,并将其存储在itemList变量中。随后,使用Array.from(itemList)将其转换为数组,方便后续的遍历操作。

Array.from(itemList)返回的数组中,使用forEach循环遍历数组的每个元素,并执行一些修改操作。根据代码逻辑,将元素的最后一个子元素放到元素的尾部,然后将元素的第一个子元素放到元素的末尾。接下来,您使用getElementsByClassName("el-collapse-item__arrow")获取带有类名el-collapse-item__arrow的元素集合,并使用Array.from将其转换为数组。在这个数组中,同样使用了forEach循环来遍历集合,并为每个元素设置了marginLeft样式为"5px"。

注:HTMLCollection 类型元素无法直接添加属性/使用方法,需先获取其中的元素,再给其添加一些属性,使用一些方法等

你可能感兴趣的:(前端问题总结,前端,javascript,html)