Vue中 使用 calc 计算长度并传参

勤奋不是嘴上说说而已,而是实际的行动,在勤奋的苦度中持之以恒,永不退却。业精于勤,荒于嬉;行成于思,毁于随。在人生的仕途上,我们毫不迟疑地选择勤奋,她是几乎于世界上一切成就的催产婆。只要我们拥着勤奋去思考,拥着勤奋的手去耕耘,用抱勤奋的心去对待工作,浪迹红尘而坚韧不拔,那么,我们的生命就会绽放火花,让人生的时光更加的闪亮而精彩。

导读:本篇文章讲解 Vue中 使用 calc 计算长度并传参,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

1. calc() 函数简介与使用

calc():英文单词 calculate (计算)的缩写,是 css3 新增加的一个功能。它可以动态的设置元素样式中 border、margin、padding 以及 width 等属性的值。

定义与用法

calc() 函数用于动态计算长度值;(支持版本:CSS3)

  1. 运算符前后都需要保留一个空格,例如:width: calc(100% – 10px);
  2. 任何长度值都可以使用 calc() 函数进行计算;
  3. calc() 函数支持 ” + “, ” – “, ” * “, ” / ” 运算;
  4. calc() 函数使用标准的数学运算优先级规则;

语法

calc(expression)
描述
expression 必须,一个数学表达式,结果将采用运算后的返回值。

浏览器支持

表格中的数字表示支持该函数的第一个浏览器版本号。
“webkit” 或 “moz” 或 “o” 指定的数字为支持该函数的第一个版本号前缀。

函数 谷歌 IE 火狐 Safari Opera
calc() 26.0 19.0 -webkit- 9.0 16.0 4.0 -moz- 7.0 6.0 -webkit- 15.0

2. 使用 calc 计算长度并传参

需求:
根据服务端返回的数组长度,来计算元素的宽度并在屏幕宽度变化时能够兼容,这是我们就可以考虑使用 calc 计算长度并传参。

2.1 完整代码

<template>
  <div>
    <div class="home">
      <div class="test1" v-for="item in resArr" :key="item" :style="div1Width()"></div>
    </div>
    <div class="test2" :style="div2Width()"></div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      resArr:[1,3,5,7] // 模拟服务端返回数据
    };
  },
  methods: {
    div1Width(){
      let arrLength = this.resArr.length;
      return `width: calc((100% - 200px)/${arrLength});`
    },
    div2Width(){
      let arrLength = this.resArr.length*100 + 'px';
      return `width: calc(100% - ${arrLength});`
    },
  }
};
</script>

<style lang="stylus" scoped>
.home{
  display:flex;
  justify-content: space-around;
  .test1{
    height:20px;
    background-color: pink;
  }
}
.test2{
  margin-top:30px;
  height:20px;
  background-color: red;
}
</style>

2.2 效果

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/141403.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!