在做项目之前老师就给我们封装好了一个js文件,解决计算中丢失精度的一些函数,直接引用js文件就可以使用。

1.什么是important

实例:
错误(无法显示出分页器按钮,此功能不适用与for循环出来的图片,只有当该页面图片固定几张时能正常用)

eg:

作用:用于提升某个直接选中标签的选择器中的某个属性的优先级,可以将被指定的属性的优先级提升为最高。

 

var numA = 0.1; 
var numB = 0.2; 
alert( numA + numB );

图片 1图片 2

第一步: 安装  npm i swiper (vue插件自带)

出现结果:0.1 + 0.2 = 0.30000000000000004 

注意点:

 

为什么出现这个问题:计算机读懂的是二进制,而不是十进制,就是程序在进制转换时候丢失了精度。

1.important只能用于直接选中,不能用于间接选中

第二步: 在当前页面里引入

解决问题代码:

p{

import Swiper from 'swiper';
import 'swiper/dist/css/swiper.min.css';
    //除法函数,用来得到精确的除法结果
    //说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显。这个函数返回较为精确的除法结果。
    //调用:accDiv(arg1,arg2)
    //返回值:arg1除以arg2的精确结果
    function accDiv(arg1, arg2) {
        var t1 = 0, t2 = 0, r1, r2;
        try { t1 = arg1.toString().split(".")[1].length } catch (e) { }
        try { t2 = arg2.toString().split(".")[1].length } catch (e) { }
        with (Math) {
            r1 = Number(arg1.toString().replace(".", ""));
            r2 = Number(arg2.toString().replace(".", ""));
            return (r1 / r2) * pow(10, t2 - t1);
        }
    }
    //乘法函数,用来得到精确的乘法结果
    //说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。
    //调用:accMul(arg1,arg2)
    //返回值:arg1乘以arg2的精确结果
    function accMul(arg1, arg2) {
        var m = 0, s1 = arg1.toString(), s2 = arg2.toString();
        try { m += s1.split(".")[1].length } catch (e) { }
        try { m += s2.split(".")[1].length } catch (e) { }
        return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m);
    }
    //加法函数,用来得到精确的加法结果
    //说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。
    //调用:accAdd(arg1,arg2)
    //返回值:arg1加上arg2的精确结果
    function accAdd(arg1, arg2) {
        var r1, r2, m;
        try { r1 = arg1.toString().split(".")[1].length; } catch (e) { r1 = 0; }
        try { r2 = arg2.toString().split(".")[1].length; } catch (e) { r2 = 0; }
        m = Math.pow(10, Math.max(r1, r2));
        return (arg1 * m + arg2 * m) / m;
    }
    //减法函数
    function accSub(arg1, arg2) {
        var r1, r2, m, n;
        try {
            r1 = arg1.toString().split(".")[1].length;
        } catch (e) {
            r1 = 0;
        }
        try {
            r2 = arg2.toString().split(".")[1].length;
        } catch (e) {
            r2 = 0;
        }
        m = Math.pow(10, Math.max(r1, r2));
        //last modify by deeka
        //动态控制精度长度
        n = (r1 >= r2) ? r1 : r2;
        return ((arg2 * m - arg1 * m) / m).toFixed(n);
    }


    //给Number类型增加一个add方法,调用起来更加方便。
    Number.prototype.add = function (arg) {
        return accAdd(arg, this);
    };
    //给Number类增加一个sub方法,调用起来更加方便
    Number.prototype.sub = function (arg) {
        return accSub(arg, this);
    };
    //给Number类型增加一个mul方法
    Number.prototype.mul = function (arg) {
        return accMul(arg, this);
    };
    //给Number类型扩展一个div方法
    Number.prototype.div = function (arg) {
        return accDiv(this, arg);
    };

  color:red  !important;  分号写在最后

 

 

}

第三步:当然呐,或许你在想内容呐,别急,为了大家的方便内容的写法我也会提供

直接将p标签选择器提升为最高

<html代码>

2.通配符选择器选中的标签也是直接选中的

<div class=”swiper-container”>
  <div class=”swiper-wrapper”>
    <div class=”swiper-slide” v-for=”item in
swiperitem”><img :src=”item.thumb”></div>(for循环)(tip:
可以把for循环换成正常展示图片,如下面展示方法,每张图对应的放进去,分页器是可以用的,for循环这样分页器是无法显示与切换的)
    < !–<div class=”swiper-slide”><img
src=”)
  </div>
  <div class=”swiper-pagination swiprRem”></div>(分页器)
</div>

分析:通配符选择器会拿到界面上的所有标签,它当然会拿到p标签,它既然能拿到p标签,它当然也算是直接选中的

<js>

  *{

vue初始化请求里添加该方法

      color:blue   !important;

mounted () {
  var that = this;
  that.$nextTick(function(){
    var mySwiper = new Swiper(“.swiper-container”,{
      direction:”horizontal”,/*横向滑动*/
       loop:true,形成环路(即:可以从最后一张图跳转到第一张图
      pagination:”.swiper-pagination”,/*分页器*/
       autoplay:3000/*每隔3秒自动播放*/
    });
  })
},

}

css就不多说了,控制大小应该都会.

图片 3图片 4

 

我们来验证一下将!important加在间接属性身上有没有效果

 

图片 5图片 6

接下来说第二个正确且简单的方法

3.!important只能提升被指定的属性的优先级,其它的属性的优先级不会被提升

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注