搜索历史展开关闭计算

使用的是原生微信小程序

API: wx.createSelectorQuery()

源代码:

var query = wx.createSelectorQuery();
query.selectAll('#id').boundingClientRect()
query.exec(function (res) {
           
              for (let index = 0; index < res[0].length; index++) {
                long = res[0][index].width +long
                num = index+1
                //循环获取每一个节点距离顶部的距离
                if (index == res[0].length-1) {
                  endTop = res[0][index].top
                }
                if (index == 0) {
                  firstTop = res[0][index].top
                }
                //计算每一个节点减去第一个节点的值加上节点本身是否大于70(70是搜索历史收缩起来的高度)
                if (res[0][index].top-firstTop>0&&res[0][index].top-firstTop+25<70) {
                  //宽度数组及个数
                  widthList[widthListIndex] = res[0][index].width+24
                  widthListIndex = widthListIndex+1

                }
              setTimeout(() => {
                //计算显示更多箭头距离左边的距离
                if (widthList!=[]) {
                  for (let index = 0; index < widthList.length; index++) {
                    leftHow = leftHow + widthList[index]-12
                    that.setData({
                      marLift:leftHow
                     })
                  }
                }
               setTimeout(() => {
                 //判断是否需要显示更多箭头
                if(endTop-firstTop+25>70){
                  that.setData({
                    isMove :true
                  })
                }else{
                  that.setData({
                    isMove:false
                  })
                }
               }, 100);
              }, 100);
            }
            
          })

就是使用wx.createSelectorQuery()获取节点的高度以及宽度。

高度的主要用处是判断是否需要展开显示更多,具体流程就是:

1、获取每一个节点距离顶部的距离

2、计算每一个节点距离顶部的距离比第一个节点距离顶部的距离大多少,如果最后一个节点加上节点自身的高度减去第一个节点距离顶部的高度大于搜索历史区域(不展开)设置的高度,则需要展开。

3、如果需要展开,就需要展示显示更多按钮,显示更多按钮距离左边的的距离就是,每个节点的宽度之和加上间距之和加上按钮距离最后一个的节点的距离。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Since 6.0.0 6.6.0 + 增加由精确分子量搜索分子式小工具(在“工具”菜单中选择) * 改进最简式结果,现在总是把碳(C)元素放在最前,其余原子按原子序数排列 * 界面上一些细节的改进 - 为适应 Window 7 及后续版本,本程序最小化后不再在任务栏隐藏,直接点击主窗口上的关闭按钮将直接退出程序 - 去掉了精简模式窗口 - 去掉了窗口“总在前面”选项 6.5.0 + 内置所有天然同位素精确质量,用户指定某种同位素的质量数时,如果恰好是天然同位素,则用内置的精确同位素质量代替用户输入的质量数(仅当原子量使用“精确值”或“最高丰度精确值”时有效)。比如如果输入{13C},则使用原子量13.0034(之前的版本直接使用13.0000) + 内置一个计算不饱和度的小工具(工具-->计算不饱和度) + 增加一个独立运行的分子式格式化工具,可以将剪贴板中的文字按一般分子式的要求将数字变成上下标 * 用户指定某种同位素时,可以不指定质量数,程序将根据“使用原子量”选项选用最高丰度的同位素的精确质量或者质量数进行计算。比如输入{H},程序将选用原子量1.0078进行计算(之前的版本将报错) * 改进了最简式结果,现在总是把碳(C)元素放在最前,氧(O)元素放在最后,更符合一般人的阅读习惯 * 大量程序界面细节的改进,现在可以在各种列表和表格中正常显示分子式,不再需要安装任何字体文件,速度也更快 * 批量计算部分重写,现在这个功能有了界面 * 主菜单上一些功能增加了快捷键,程序中个别快捷键修改 * 程序全面支持UNICODE - RTF格式历史记录合并到“历史记录”中,原RTF格式历史记录选项不再有效 - 修正一个前端显示时主窗口可能遮住对话窗口的BUG 6.4.1 + 增加批量计算功能,在“工具”菜单中,一些过长的分子式可以从文件中导入防止显示速度过慢 - 修正一处同位素质量数显示问题 - 修正统计基团时潜在的问题 * 改进历史记录存盘文件样式 6.4.0 + 增加一个选项,可以选择不即时给出结果,以加快输入速度 - 修正在输入很长分子式时光标移出输入框的问题 * 改写内核,大幅提高大小写自动判断速度,尤其含有大量缩写时 * 改写内核,提高计算速度 * 将氨基酸缩写改为更简洁形式,提高计算速度 * 一些细节的优化,提高效率 6.3.0 + 缩写设定中缩写值首字母为"_"(英文下划线)时将忽略此项 + 默认设定下加入20种氨基酸残基的缩写(每种去掉一分子水) - 修正某对话框中的错别字 - 修正缩写设定对话框中不能输入"="的问题 - 修正缩写设定中缩写为空时造成的程序错误 - 修正安装后在C盘根目录下留下CHEM_4.TTF文件的问题 - 修正卸载后不能删除快速启动栏快捷方式的问题 * 增强监视剪贴板的兼容性:自动忽略复制到剪贴板中的分子式中前后的空格 * 缩写设定对话框和原子量设定对话框中按ESC可以直接关闭 6.2.2 - 修正某些情况下重复运行程序窗口不能弹出的问题 - 修正有时程序退出时会弹出调试对话框的问题 6.2.1: - 修正窗口隐藏时检测到剪贴板变化不能弹出的问题 6.2.0: + 增加两个选项:是否启用历史记录功能,如果禁用,可以加快计算速度,默认开启 + 增加设置窗口的快捷键为F10 + 自定义原子量窗口增加快速功能 + 增加展开缩写的功能,在编辑菜单中 - 修正输入分子式长度有限制的bug * 程序界面细小改进:在关于窗口点击版本号弹出ChangeLog * 程序细节的改进 6.1.1: + 增加分子量计算器主页 - 修正分子式括号中角标显示不正确的问题 * 程序细节的改进 6.1.0: + 增加一套最大丰度同位素精确原子量表 - 修正“质量数”原子量表为丰度最大同位素质量数 - 修正RTF历史窗口一处显示的问题 - 修正程序启动时不能装入原子量选项的bug * 改进了核心代码,提高效率 * 程序细节的改进 6.0.0: + 新增支持计算化学式中某些特定的基团的质量分数 + 自动保存用户设置在INI文件中 + 保存历史记录支持纯文本以及RTF两种格式 + 将元素统计结果复制到剪贴板时将有更多选择 + 简易模式窗口可以自动隐藏 - 彻底解决了当化学式中存在缩写基团时可能会发生的问题 * 程序启动时自动判断是否安装“Chemistry Numbers”字体以采取不同的显示策略,在没有字体的情

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值