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

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

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 效果

2020062310470442.png



相关文章
|
1天前
|
JavaScript
Vue的小知识点
Vue的小知识点
7 2
|
1天前
|
JavaScript Apache
Vue升级及版本不匹配解决_Vue packages version mismatch:
Vue升级及版本不匹配解决_Vue packages version mismatch:
7 1
|
1天前
|
JavaScript 定位技术
BIGEMAP地图VUE中引入
BIGEMAP地图VUE中引入
3 0
BIGEMAP地图VUE中引入
|
1天前
|
JavaScript
vue点击按钮复制文字到粘贴板
vue点击按钮复制文字到粘贴板
6 0
|
1天前
|
JavaScript 定位技术 开发者
vue项目使用腾讯地图获取定位
vue项目使用腾讯地图获取定位
4 0
|
1天前
|
JavaScript 开发者
如何新建一个vue+vant移动端项目
如何新建一个vue+vant移动端项目
6 0
|
5天前
|
前端开发 JavaScript
Vue底层实现原理总结
Vue底层实现原理总结
|
10天前
|
JavaScript 前端开发 测试技术
使用 Vue CLI 脚手架生成 Vue 项目
通过 Vue CLI 创建 Vue 项目可以极大地提高开发效率。它不仅提供了一整套标准化的项目结构,还集成了常用的开发工具和配置,使得开发者可以专注于业务逻辑的实现,而不需要花费大量时间在项目配置上。
71 7
使用 Vue CLI 脚手架生成 Vue 项目
|
1天前
|
JavaScript
Vue全局注册与局部注册异同点
Vue全局注册与局部注册异同点
12 6