关于vant2 组件van-dropdown-item,在IOS手机上,特定条件下无法点击问题的探讨

news2025/1/9 1:33:18

情景重现

先贴有问题的代码

<template>
  <div :class="showBar ? 'homeContain' : 'homeContain-nobar'">
    <div class="contant" id="content">
      <van-dialog v-model="loading" :before-close="onBeforeClose" :show-confirm-button="false">
        <div style="text-align: center; line-height: 100px">
          <van-loading size="24px">加载中...</van-loading>
        </div>
      </van-dialog>

      <div>
        <div class="contian-title-div">
          <div style="display: flex">
            <div class="contain-title">{{ hospitalName }}</div>
            <van-dropdown-menu style="flex: 1">
              <van-dropdown-item
                v-model="valueUserName"
                :options="optionUserName"
                @change="userNameChange"
              />
            </van-dropdown-menu>
          </div>
        </div>

        <div v-if="list.length === 0">
          <div class="text-center" style="padding-top: 60px; height: 70vh">
            <div class="back-white pad-16 border-r-10">
              <img src="@/assets/images/room/noHos.png" width="150" />
              <h3>暂无排队记录</h3>
            </div>
          </div>
        </div>
        <div style="display: flex; flex-direction: column" v-else>
          <div style="overflow-y: scroll; height: 72vh">
            <van-list
              @load="onLoad"
              style="margin: 10px; flex: 2 1 0%; margin-top: 1.6rem"
            >
              <div
                class="back-white pad-16 border-r-10"
                style="margin: 1em 0 0 0"
                v-for="item in list"
                :key="item.id"
              >
                <div>
                  <img
                    src="@/assets/images/icon/boy.png"
                    class="contain-img"
                    v-if="userSex === 1"
                  />
                  <img
                    src="@/assets/images/icon/girl.png"
                    class="contain-img"
                    v-if="userSex === 2"
                  />
                  <div style="display: flex; padding: 8px">
                    <div class="contain-div1">
                      <div class="contain-name">{{ item.patientName }}</div>
                      <div
                        class="gray-9"
                        style="font-size: 14px"
                        v-if="userPhone"
                      >
                        {{
                          userPhone.replace(/(\d{3})\d{4}(\d{4})/, "$1****$2")
                        }}
                      </div>
                    </div>
                    <div class="contain-div-right">
                      <div class="contain-name">{{ item.deptName }}</div>
                      <div class="gray-9" style="font-size: 14px">
                        {{ item.orgName }}
                      </div>
                    </div>
                  </div>
                </div>

                <div class="boxcard" style="margin-top: 10px">
                  <div>
                    <div
                    class="div-notice"
                    style="  margin-bottom: 10px;"
                      v-if="item.seeNo - item.seeingNo > 0"
                    >
                      {{ item.seeingName }} {{ item.seeingNo }} {{ item.seeingDocTime?'('+item.seeingDocTime+')':'' }}
                      
                    </div>
                    <div
                      style="text-align: center"
                      class="gray-9"
                   
                    >
                      当前叫号
                    </div>
                  </div>
                  <div>
                    <div
                      class="div-notice"
                      v-if="item.seeNo - item.seeingNo < 0"
                    >
                    现已过您的号码, <br>如有疑问请咨询服务台
                    </div>
                    <div
                      class="div-notice"
                      v-if="item.seeNo - item.seeingNo == 0"
                    >
                      请至{{ item.deptName }}诊室就诊
                    </div>
                    <div style="text-align: center" class="gray-9"></div>
                  </div>

                  <van-row style="margin-top: 10px">
                    <van-col span="12">您的号码:{{ item.seeNo }}</van-col>
                    <van-col
                      span="12"
                      style="
                        align-items: flex-end;
                        display: flex;
                        flex-direction: column;
                      "
              
                      >预约时间: {{ item.seeDocTime?item.seeDocTime:'-:-' }}</van-col
                    >
                  </van-row>
                </div>
              </div>
            </van-list>
          </div>
        </div>
        <div style="margin: 20px">
          <van-button
            round
            block
            type="primary"
            @click="refreshList()"
            :loading="submitBol"
            loading-text="刷新中..."
            >刷新</van-button
          >
          <div class="last-fresh-time" v-if="lastRefreshTime">
            最后刷新时间:{{ lastRefreshTime }}
          </div>
        </div>
      </div>
    </div>
  </div>
</template>

样式

<style scoped>
.last-fresh-time {
  display: flex;
  justify-content: center;
  margin: 10px;
  font-size: 12px;
  color: #9b9b9b;
}

.contian-title-div {
  position: fixed;
  width: 100%;
  line-height: 0.58667rem;
  background: #fff;
}
.contain-title {
  flex: 1 1 0%;
  background-color: #fff;
  position: relative;
  align-items: center;
  display: flex;
  justify-content: center;

  color: #323233;
  font-size: 14px;
  line-height: 0.58667rem;
}
.contain-img {
  height: 45px;
  width: 45px;
  border-radius: 50%;
  float: left;
  margin-right: 5px;
}
.contain-name {
  font-size: 14px;
  font-weight: 600;
}
.contain-div1 {
  flex: 1;
  margin-left: 5px;
}
.contain-div-right {
  flex: 1;
  margin-right: 5px;
  align-items: flex-end;
  display: flex;
  flex-direction: column;
}
.contant {
  padding: 0;
}
.van-dropdown-menu >>> .van-dropdown-menu__bar {
  box-shadow: 0 0 0;
}

.div-notice {
  text-align: center;
  font-size: 18px;
  font-weight: 550;
  margin-top: 20px;
  margin-bottom: 20px;
}
</style>

van-dropdown-menu >>> .van-dropdown-menu__bar

这一行是对组件内的样式进行了修改
上个图直观一些
在这里插入图片描述

在这里插入图片描述
右上角人名可以切换,用到的就是van-dropdown-menu,这个在web,在android,都没有问题,但是在IOS机型上,有时候点击没反应。刚开始以为是不兼容,但是在某些情况下又能切换,所以排除了不兼容的情况,多次试验以后,发现在排队列表没有数据的情况下,可以切换,有数据的情况下,不能切换
经过排查,一个一个修改,试验,是一个样式引起的问题

.contian-title-div {
  position: fixed;
  width: 100%;
  line-height: 0.58667rem;
  background: #fff;
}

把这个 position: fixed;删掉,在IOS上,和van-dropdown-menu有冲突,会出现点击没反应的问题

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/881989.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

css鼠标样式 cursor: pointer

cursor: none; cursor:not-allowed; 禁止选择 user-select: none; pointer-events:none;禁止触发事件, 该样式会阻止默认事件的发生&#xff0c;但鼠标样式会变成箭头

openpose姿态估计【学习笔记】

文章目录 1、人体需要检测的关键点2、Top-down方法3、Openpose3.1 姿态估计的步骤3.2 PAF&#xff08;Part Affinity Fields&#xff09;部分亲和场3.3 制作PAF标签3.4 PAF权值计算3.5 匹配方法 4、CPM&#xff08;Convolutional Pose Machines&#xff09;模型5、Openpose5.1 …

【uniapp2】获取manifest里的versionName版本号

在要展示版本号的页面中添加&#xff1a; onLoad() {// 获取本地应用资源版本号plus.runtime.getProperty(plus.runtime.appid, (wgtinfo) > {this.innerVer wgtinfo.version;this.versionCode wgtinfo.versionCode;console.log(wgtinfo);});},打印看看获取的信息&#x…

机器学习---逻辑回归代码

1. 逻辑回归模型 import numpy as npclass LogisticRegression(object):def __init__(self, learning_rate0.1, max_iter100, seedNone):self.seed seedself.lr learning_rateself.max_iter max_iterdef fit(self, x, y):np.random.seed(self.seed)self.w np.random.normal…

视频汇聚平台EasyCVR安防监控视频汇聚平台的FLV视频流在VLC中无法播放的问题解决方案

众所周知&#xff0c;TSINGSEE青犀视频汇聚平台EasyCVR可支持多协议方式接入&#xff0c;包括主流标准协议国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。在视频流的处理与分发上&#xff0c;视频监控…

ESP8266获取网络时间 实时时钟

程序现象 一、用串口调试助手调试 1.发送指令ATRST重启模块使应用模式更改生效&#xff1b; 2.发送指令ATE0取消回显 3.使用串口发送指令ATCWMODE1设置模块Wi-Fi应用模式为Station模式&#xff1b; 4.发送指令ATCWJAP "ssid","pwd"连接AP&#xff1b; …

react-native-webview RN和html双向通信

rn登录后得到的token需要传递给网页&#xff0c;js获取到的浏览器信息需要传递给rn RN Index.js: import React from react import { WebView } from react-native-webview import useList from ./useListexport default function Index(props) {const { uri, jsCode, webVie…

23款奔驰S450 4MATIC升级车载冰箱系统,快乐就是这么朴实无华呀

凉爽餐饮随时触手可及。容积10升的可拆卸冷藏箱与后排扶手和谐融合。如此一来&#xff0c;即使在炎炎夏日&#xff0c;也可享受沁凉的冷饮。

Vue3头像(Avatar)

效果如下图&#xff1a;在线预览 APIs 参数说明类型默认值必传shape指定头像的形状‘circle’ | ‘square’‘circle’falsesize设置头像的大小number | ‘large’ | ‘small’ | ‘default’ | Responsive‘default’falsesrc图片类头像资源地址string‘’falsealt图片无法显…

关于微信临时文件wxfile://tmp文件如何处理,微信小程序最新获取头像和昵称

分享-2023年资深前端进阶&#xff1a;前端登顶之巅-最全面的前端知识点梳理总结&#xff0c;前端之巅 *分享一个使用比较久的&#x1fa9c; 技术栈&#xff1a;taro框架 vue3版本 解决在微信小程序获取微信头像时控制台报错&#xff1a;找不着wxfile://tmp 文件路径,失败&…

迁移协调器 - 就地迁移模式

在本系列博客的第一部分中&#xff0c;我们从高层级视角介绍了 Migration Coordinator 提供的所有模式&#xff0c;Migration Coordinator 是内置于 NSX 中的完全受 GSS 支持的工具&#xff0c;可将 NSX for vSphere 迁移到 NSX (NSX-T)。 本系列的第二篇博客将详细介绍就地迁…

cesium 卫星环绕扫描

成果图 源码 let viewer new Cesium.Viewer(cesiumContainer,{// terrainProvider: Cesium.createWorldTerrain(),geocoder: false, // 隐藏查找位置homeButton: false, // 隐藏返回视角到初始位置sceneModePicker: false, // 隐藏视角模式的选择baseLayerPicker: false, // 隐…

亚马逊云科技助力珠海丹德构建安全技术底座,促进商业发展

随着消费者对商品质量和安全关注度的不断提高&#xff0c;防伪、溯源、防窜已经成为企业关注的重要领域。据前瞻产业研究院数据显示&#xff0c;2028年中国防伪行业市场容量将超过4000亿元&#xff0c;未来市场对防伪、溯源、防窜技术的需求和重视程度可见一斑。 作为一家用智慧…

软件测试项目实战,电商业务功能测试点汇总(全覆盖)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 支付功能怎么测试…

医院后勤管理用什么系统好?的修医院报修管理系统有哪些优势?

随着医院后勤工作量的不断增加&#xff0c;需要协调和维护的设备和部门也随之增多。传统的医院后勤管理方式已经显得不够优越&#xff0c;其劣势日益凸显&#xff0c;无法满足实际工作需求。因此&#xff0c;快速推动医院后勤信息化管理已成为当前医院发展的迫切需求。而的修医…

进销存记账软件2023排行榜,秦丝、智慧记、管家婆哪家更好用?

进销存记账软件已经成为很多实体店必备的一款软件&#xff0c;使用进销存记账软件可以帮助实体店解决手工记账效率低下、对账麻烦且出错率高等问题。 很多实体店都是小本生意&#xff0c;选择进销存记账软件时由于缺乏经验&#xff0c;随意选择&#xff0c;结果买回来之后一堆问…

无人机跟随一维高度避障场景--逻辑分析

无人机跟随一维高度避障场景--逻辑分析 1. 源由2. 视频3. 问题3.1 思维发散3.2 问题收敛 4. 图示4.1 水平模式4.2 下坡模式4.3 上坡模式4.4 碰撞分析 5. 总结6. 参考资料 1. 源由 最近拿到一台测试样机&#xff0c;功能很多&#xff0c;就不多赘述。 这里针对跟随功能进行下吐…

java面试基础 -- 方法重载 方法重写

目录 重载 重写 重载 方法的重载是指在同一个类中定义多个方法, 他们具有相同的名称, 但是具有不同的参数列表, 例如: public void myMethod(int arg1) {// 方法体 }public void myMethod(int arg1, int arg2) {// 方法体 }public void myMethod(String arg1) {// 方法体 }…

企业权限管理(九)-用户操作

用户操作 1用户查询 UserController findAll Controller RequestMapping("/user") public class UserController {Autowiredprivate IUserService userService;RequestMapping("/findAll.do")public ModelAndView findAll() throws Exception {ModelAndVie…