收藏
回答

小程序position设置为static后。影响了全局

框架类型 问题类型 操作系统 工具版本
小程序 Bug Windows 1.02.1803210


只是更改了提交作业与查看的position为static。反而影响了整个页面多了个边框?为什么

回答关注问题邀请回答
收藏

1 个回答

  • 自己这个傻逼
    自己这个傻逼
    2018-07-20

        这可能是小程序的一个BUG。我也遇到过这种情形,简化问题,可以描述如下:


    假设有页面如下:

    <view>
      <button bind:tap='FuncTest' style='position:static;background-color:green;'>TEST</button>
    </view>


    其中FuncTest定义如下:

    FuncTest:function(e){
      console.log('click test');
    }

    运行效果如图



    预期的结果是点击TEST按钮时,日志输出click test

    但测试会发现,无论点屏幕哪里,即便在TEST按钮范围之外,日志也会输出click test。也就是说,此时的按钮覆盖到整个界面了。


    暂时没有解决的方法,只能是不使用position:static


    另外,查阅了w3school的文档,其中对于position的取值解释如下:

    可能的值

    描述
    absolute

    生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。

    元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

    fixed

    生成绝对定位的元素,相对于浏览器窗口进行定位。

    元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

    relative

    生成相对定位的元素,相对于其正常位置进行定位。

    因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。

    static默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。
    inherit规定应该从父元素继承 position 属性的值。


    注意到static本就是position的默认值。但是在小程序中却会因为加上它而外观和行为发生变化。可见在小程序中,static不是默认值。小程序并没有遵循标准CSS的定义。

    2018-07-20
    有用
    回复
登录 后发表内容