RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1577335
Accepted
Дима Й
Дима Й
Asked:2024-04-23 00:34:53 +0000 UTC2024-04-23 00:34:53 +0000 UTC 2024-04-23 00:34:53 +0000 UTC

更新 Bootstrup 5 工具提示中的文本(不带动画)

  • 772

当 ajax 响应到达时,我使用此设计来更新工具提示中的文本。

 let element = document.getElementById('idElement');
 const tooltipElement = bootstrap.Tooltip.getOrCreateInstance(element)
 tooltipElement.setContent({'.tooltip-inner': 'New text'})

这段代码有效。但更新的时候这个提示逐渐消失又出现。如何在不闪烁的情况下更新工具提示内容?也许,您需要以某种方式在更新阶段禁用动画或使用其他方法来更新工具提示。完全禁用动画是不合适的。引导程序 5.3.0-alpha3

javascript
  • 1 1 个回答
  • 35 Views

1 个回答

  • Voted
  1. Best Answer
    yar85
    2024-05-01T08:30:21Z2024-05-01T08:30:21Z

    目前看来,在 Bootstrap 5 中切换工具提示实例动画(不更改全局设置)的唯一方法是通过_config.animation. 在这种情况下:

    tooltipElement._config.animation = <true|false>;
    

    演示,以及引导我们选择拐杖选项的逻辑:

    const tooltipTriggerList = document.querySelectorAll('[data-bs-toggle="tooltip"]');
    const tooltipList = [...tooltipTriggerList].map(tooltipTriggerEl => new bootstrap.Tooltip(tooltipTriggerEl));
    
    let element = document.getElementById('test');
    const tooltipElement = bootstrap.Tooltip.getOrCreateInstance(element);
    
    // для демонстрации, замена текста в асинхронном цикле (каждые 2с)
    setInterval(() => {
      time = (new Date()).toLocaleTimeString();
      tooltipElement._config.animation = false;
      tooltipElement.setContent({'.tooltip-inner': `New text ${time}`});
      tooltipElement._config.animation = true;
    }, 2e3);
    body  { padding: 1rem; }
    #test { border: 1px solid #ccc; cursor: default; }
    <link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-QWTKZyjpPEjISv5WaRU9OFeRpok6YctnYmDr5pNlyT2bRjXh0JMhjY6hW+ALEwIH" crossorigin="anonymous">
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js" integrity="sha384-YvpcrYf0tY3lHB60NNkmXc5s9fDVZLESaAA55NDzOxhy9GkcIdslK1eN7N6jIeHz" crossorigin="anonymous"></script>
    
    <span id="test" class="px-4 py-2" data-bs-toggle="tooltip" 
      data-bs-placement="bottom" data-bs-title="Tooltip on bottom"
    >
      Tooltip demo
    </span>

    根据Bootstrap 5.3文档(回答时的当前版本),可以通过更改数据属性来控制属性值,即 立即采用标准的、明显的路径:

    element.dataset.bsAnimation = false;
    

    ,但事实证明,在运行时更改数据属性没有任何效果……引导程序仍然保持原来的样子💩。如果我们查看框架代码,我们会发现在显示工具提示时,仅考虑内部配置对象,而不尝试读取元素的数据属性。这就是第 240 行animation方法中使用的参数值 getter的内部实现方式:show

    _isAnimated() {
      return this._config.animation || (this.tip && this.tip.classList.contains(CLASS_NAME_FADE))
    }
    

    (有一个方法_getConfig可以读取它,但实际上显示时并没有调用它🤷)

    因此:由于框架中有关 JS API(和/或其官方网站上的文档)的缺陷,通过脚本更改 Tooltip 组件配置的唯一选择是覆盖无证财产_config。
    通过 hack 的解决方案当然是不好的,但是没有其他选择......而且它似乎比双重调用内部解决方案更邪恶_getConfig,它执行更多操作,因此可能会产生不需要的副作用(例如,我假设title它也会覆盖工具提示)。

    • 1

相关问题

  • 第二个 Instagram 按钮的 CSS 属性

  • 由于模糊,内容不可见

  • 弹出队列。消息显示不正确

  • 是否可以在 for 循环中插入提示?

  • 如何将 JSON 请求中的信息输出到数据表 Vuetify vue.js?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5