atjs参数有哪些?如何正确配置与使用?

at.js 是一个轻量级的 JavaScript 库,主要用于实现文本输入框中的自动补全功能,常见于社交平台、评论系统等需要@提及、标签补全的场景,其核心行为通过参数配置实现,合理设置参数能让开发者精准控制触发条件、数据交互、UI 展示等逻辑,以下从参数类型、作用场景及示例出发,详细解析 at.js 的关键参数。

atjs参数

at.js 参数详解

at.js 的参数通过初始化时传入对象配置,主要可分为触发控制、数据交互、UI 展示、回调函数四大类,具体参数如下表所示:

参数名 类型 默认值 作用说明 示例
trigger String 设置触发自动补全的字符,支持多字符(如 ‘#@’)或正则表达式。 trigger: '@'(触发@提及);trigger: '#@'(需输入#@才触发)
searchKey String ‘value’ 指定数据源中用于搜索的字段名,与后端返回数据字段对应。 若后端返回 {id: 1, name: '张三'},则 searchKey: 'name'
displayTpl String

  • ${value}
  • 下拉列表项的 HTML 模板,支持通过 ${字段名} 插入数据。displayTpl: '<li><img src="${avatar}"/>${name}</li>'(显示头像和姓名)
    insertTplString‘${value}’选中补全项后插入输入框的内容模板,可自定义格式(如带链接、标签)。insertTpl: '@${name}(${id})'(插入@张三(1))
    delayNumber300输入触发字符后,发送搜索请求的延迟时间(毫秒),避免频繁请求。delay: 500(输入后等待500ms再请求)
    maxItemsNumber5下拉列表最大显示数量,超出部分滚动显示。maxItems: 10(最多显示10条补全项)
    minCharsNumber0触发补全所需的最小字符数(如输入@后需再输入1个字符才触发搜索)。minChars: 1(输入@后需再输入至少1个字符)
    hideDropdownOnSelectBooleantrue选中补全项后是否自动隐藏下拉框。hideDropdownOnSelect: false(选中后仍显示下拉框)
    highlightFirstBooleanfalse是否自动高亮下拉列表的第一项,支持回车键快速选中。highlightFirst: true(默认选中第一项)
    callbacksObject配置生命周期回调函数,包括请求前、请求后、选中后等钩子。见下方“回调函数参数说明”

    回调函数参数说明

    callbacks 是 at.js 最灵活的部分,通过不同回调函数可自定义数据请求、数据处理逻辑:

    atjs参数

    • beforeQuery(query, callback):发送请求前的回调,query 为当前输入内容,callback 控制是否请求(如 callback({results: []}) 可直接返回数据)。
      示例:过滤空请求

      callbacks: {
        beforeQuery: function (query, callback) {
          if (query.length < 2) callback({results: []}); // 输入不足2字符不请求
          else callback();
        }
      }
    • afterRender($ul):下拉列表渲染后的回调,$ul 为 jQuery 对象,可自定义样式或事件。
      示例:为列表项添加点击事件

      afterRender: function ($ul) {
        $ul.find('li').on('click', function () {
          console.log('选中项:', $(this).data('item'));
        });
      }
    • afterInsert(value, $input):选中项插入输入框后的回调,value 为插入内容,$input 为输入框元素。
      示例:插入后清空输入框(如标签场景)

      afterInsert: function (value, $input) {
        $input.val(''); // 插入后清空输入,继续输入新标签
      }

    参数组合应用示例

    实现一个带头像的@提及功能,后端返回 {id: 1, name: '张三', avatar: 'url'},配置如下:

    $('#input').atwho({
      at: '@',              // 触发字符为@
      searchKey: 'name',    // 搜索name字段
      displayTpl: '<li><img src="${avatar}" width="20"/>${name}</li>', // 显示头像和姓名
      insertTpl: '@${name}', // 插入@张三
      delay: 400,           // 400ms延迟请求
      maxItems: 8,          // 最多显示8条
      callbacks: {
        afterInsert: function (value, $input) {
          console.log('插入内容:', value); // 插入后打印日志
        }
      }
    });

    相关问答 FAQs

    Q1:at.js 参数中的 beforeQueryafterQuery 有什么区别?
    A:beforeQuery 在发送请求前触发,可修改请求数据或直接返回本地数据(避免请求后端),适合缓存或过滤场景;afterQuery 在收到后端响应后触发,可对返回数据二次处理(如格式化、过滤空值),但无法阻止请求发送。beforeQuery 可判断本地是否有缓存数据,有则直接返回;afterQuery 可将后端返回的 {data: [...]} 提取为 [...] 供 at.js 渲染。

    atjs参数

    Q2:如何通过 at.js 参数实现自定义的@提及样式?
    A:通过 displayTpl 参数自定义 HTML 模板,结合 CSS 样式实现,设置 displayTpl: '<li class="mention-item"><span class="name">${name}</span><span class="id">#${id}</span></li>',并在 CSS 中定义 .mention-item { display: flex; align-items: center; padding: 5px; } .name { font-weight: bold; } .id { color: #999; margin-left: 5px; },即可实现带姓名和ID的@提及样式,同时通过 afterRender 回调可添加动态交互(如悬停高亮)。

    原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/47782.html

    (0)
    酷番叔酷番叔
    上一篇 7小时前
    下一篇 6小时前

    相关推荐

    • 如何轻松操作图形界面?

      在Linux系统中,命令行界面(CLI)是与系统交互的核心工具,无论是管理文件、安装软件还是排查故障都离不开它,以下是多种打开命令行界面的详细方法,适用于不同场景和Linux发行版(如Ubuntu、Fedora、CentOS等):快捷键启动终端通用快捷键:Ctrl + Alt + T(适用于Ubuntu、Deb……

      2025年7月4日
      5600
    • Lisp中caddr如何快速提取列表元素?

      caddr 的核心功能caddr 用于提取列表的第三个元素,它是Lisp中 car 和 cdr 函数的组合:car:返回列表的第一个元素,cdr:返回移除第一个元素后的子列表,caddr = car + cdr + cdr,即连续两次 cdr 后取 car,最终定位到第三个元素,函数逻辑分解:(caddr……

      2025年7月12日
      4400
    • 如何高效掌握Red Hat命令技巧?

      Red Hat Enterprise Linux(RHEL)是广泛使用的企业级操作系统,其命令行界面(CLI)是系统管理的核心工具,本文详细解析常用命令及其应用场景,帮助用户高效管理服务器,以下内容基于 RHEL 8/9 环境,符合企业级最佳实践,基础文件操作命令目录与文件管理ls:列出目录内容 ls -l……

      2025年7月17日
      4300
    • 如何更新软件源获取最新信息?

      为什么必须更新Linux软件?安全修复:及时修补漏洞,防止恶意攻击,功能优化:获取新特性和性能改进,依赖管理:避免软件冲突,确保系统兼容性,稳定性提升:修复已知错误,减少崩溃风险,专业建议:更新前务必备份重要数据,生产环境建议先在测试机验证,各发行版更新命令详解Debian/Ubuntu 及其衍生版(APT工具……

      2025年6月28日
      5100
    • CAD如何关闭光标旁命令提示栏?

      关闭AutoCAD光标旁命令提示栏(动态输入)的方法:,1. **点击状态栏**:找到屏幕底部的状态栏。,2. **关闭“DYN”按钮**:点击“动态输入”图标(通常显示为“DYN”),使其变为灰色(关闭状态)。,**或**,1. **输入系统变量**:在命令行输入 DYNMODE 然后按回车。,2. **设置为0**:输入 0 然后按回车。

      2025年7月17日
      4200

    发表回复

    您的邮箱地址不会被公开。 必填项已用 * 标注

    联系我们

    400-880-8834

    在线咨询: QQ交谈

    邮件:HI@E.KD.CN

    关注微信