zoukankan      html  css  js  c++  java
  • uni-app知识点:页面滚动到指定位置(即锚点实现)、设置背景颜色backgroundColor无效的问题、导航栏设置角标及动态控制修改角标数字

    一、页面滚动到指定位置(即实现锚点的功能)

      项目需求:在页面中,不管位于何处,点击评论按钮页面滚动到对应的评论位置。

      解决方案:将uniapp的uni.createSelectorQuery()方法与uni.pageScrollTo(OBJECT)方法结合使用。

    更详细用法见官方文档:

    uni.createSelectorQuery()方法: https://uniapp.dcloud.io/api/ui/nodes-info?id=createselectorquery

    uni.pageScrollTo(OBJECT)方法: https://uniapp.dcloud.io/api/ui/scroll?id=pagescrollto

      实现思路如下:

    uni.createSelectorQuery().select("#Comment").boundingClientRect((res)=>{
      uni.pageScrollTo({
        duration:0,
        scrollTop:res.top
      })
    }).exec();

      但是你会发现,在页面没有滚动之前点击评论按钮可以直接滚动到评论,如果我页面有滚动,滚动距离就会出现偏差。

      这是因为滚动到实际距离是元素距离顶部的距离减去最外层盒子的滚动距离。

      最终实现代码如下:

    toComment () {
      uni.createSelectorQuery().select('.article-box').boundingClientRect(data => {
        uni.createSelectorQuery().select('#Comment').boundingClientRect(res => {
          uni.pageScrollTo({
            scrollTop: res.top - data.top - 10
          })
        }).exec()
      }).exec()
    }

      其中uni.createSelectorQuery()有一点需要注意的是下面这点:selectorQuery.in(component),它是将选择器的选取范围更改为自定义组件 component 内,返回一个 SelectorQuery 对象实例。(初始时,选择器仅选取页面范围的节点,不会选取任何自定义组件中的节点)。

    二、在uni-app项目中设置背景颜色和微信小程序设置 backgroundColor无效的问题

      在DCloud的官方提供的文档中写的方法是这样,如下

      但是实际设置了之后,没有作用,然后搜了一下说是因为 backgroundColor 指的窗体背景颜色,而不是页面的背景颜色,即窗体下拉刷新或上拉加载时露出的背景参考链接

      因此采用了直接在全局样式中设置page的样式(也可以写在app.vue中),如下:

    page {
        background-color: #FFFFFF;
    }

    三、导航栏设置角标及动态控制修改角标数字

    1、导航栏设置角标:

    "buttons": [...,{
      "fontSrc": "/static/uni.ttf",
      "text": "ue873",
      "fontSize": "22px",
      "color": "#999999",
      "badgeText": "0"
    }],

      比较简单,直接按官网文档来即可。其中:badgeText 就是用来设置角标数字的。

    2、动态修改角标数字

    (1)创建角标:注意角标的index,只有app下才可以使用哦

    // #ifdef APP-PLUS
    let pages = getCurrentPages();
    let page = pages[pages.length - 1];
    let currentWebview = page.$getAppWebview();
    currentWebview.setTitleNViewButtonBadge({ index: 0, text: '10' });  //text必须是string类型
    // #endif

    (2)移除角标

    currentWebview.removeTitleNViewButtonBadge({ index: 0 });
  • 相关阅读:
    图形设计 X11
    软件安装 RPM SRPM YUM
    如何将excel表格中的纯数字删掉 空白行,然后删除
    考试机
    程序编译与运行
    基础设定与备份策略
    开机流程 模块管理 Loader
    让所有Excel数据格全部乘 某个数
    转:JDK1.8-Stream()使用详解
    转:IK分词原理
  • 原文地址:https://www.cnblogs.com/goloving/p/14257964.html
Copyright © 2011-2022 走看看