npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

lcap-markdown-doc-search

v0.1.4

Published

<!-- 该 README.md 根据 api.yaml 和 docs/*.md 自动生成,为了方便在 GitHub 和 NPM 上查阅。如需修改,请查看源文件 -->

Downloads

5

Readme

LcapMarkdownDocSearch 文档搜索框

Other

请在这里添加描述

示例

基本用法

<template>
<div>

  <lcap-markdown-doc-search
    ref="search"
    placeholder="请输入"
    :value.sync="value"
    :data-source="suggestions"
    text-field="highlightedTitle"
    description-field="highlightedContent"
    @input="onInput"
    @change="onChange"
  ></lcap-markdown-doc-search>

  <button @click="onSearch">搜索</button>  
</div> 


</template>

<script>
export default {
  data() {
    return {
      value: '',
      suggestions: []
    }
  },

  methods: {
    onSearch() {
      this.$refs.search.focus()
    },
    fetchData(keywords) {
      setTimeout(() => {
        if (!keywords) {
          this.suggestions = [];
        } else {
        this.suggestions = [
        {
          "esId": "2614959179281664",
          "highlightedContent": "<mark>组件</mark>列表  该<mark>组件</mark>可将其他<mark>组件</mark>根据动态数据源进行动态展示,如根据列表数据循环展示 N 个文本/标签等。  <mark>组件</mark>说明  属性  «<mark>组件</mark>通用属性请参见<mark>组件</mark>通用说明。»  数据属性  «<mark>组件</mark>数据源、数据类型、初始加载属性请参见<mark>组件</mark>数据源说明。»  样式属性  - 每行排列项数:支持定义每一行排列的项数,为空时会自适应宽度并自动换行。",
          "highlightedTitle": "<mark>组件</mark>列表"
        },
          
          {"esId":"2614959176684800","highlightedContent":"<mark>组件</mark>通用说明  每个<mark>组件</mark>都包含属性、事件和样式。其中大部分功能以及设置方式相同,本节对<mark>组件</mark>的通用属性做详细说明。  属性  基础信息  - <mark>组件</mark>名称:由字母、数字和下划线组成,用于在表达式中引用、权限上报等场景。  - 是否控制权限:可根据角色设置权限,对无权限的角色的用户隐藏该<mark>组件</mark>,设置权限前,必须先设置<mark>组件</mark>名称。","highlightedTitle":"组件通用说明"},{"esId":"2614959180682496","highlightedContent":"案例  使用<mark>组件</mark>列表实现一个每行展示6个标签的效果  1、页面拖入<mark>组件</mark>列表  2、绑定数据源、设置每行排列项数  3、拖入标签<mark>组件</mark>  4、标签<mark>组件</mark>设值  5、效果展示","highlightedTitle":"组件列表"},{"esId":"2614959180272896","highlightedContent":"- 只读:设置多行输入<mark>组件</mark>只读。  - 禁用:设置多行输入<mark>组件</mark>禁用变灰不可编辑。  <mark>组件</mark>事件  - 支持基本的手势事件:获得焦点和失去焦点。","highlightedTitle":"多行输入"},{"esId":"2614959178183936","highlightedContent":"- 禁用:禁用开关,开启后鼠标移入<mark>组件</mark>区域内无法点击,且会显示禁用标记。  - 标签:顶部自定义提示文本。  - flag标志:是否右上角有flag标志。  事件  - 面包屑<mark>组件</mark>支持<mark>组件</mark>事件。     - <mark>组件</mark>事件:选择前、输入时、选择后、改变后。  - 面包屑选项支持鼠标事件和<mark>组件</mark>事件。     - 鼠标事件:点击。     - <mark>组件</mark>事件:选择前。  样式  样式说明请参见<mark>组件</mark>通用说明。","highlightedTitle":"胶囊"},{"esId":"2614959177823488","highlightedContent":"<mark>组件</mark>说明  属性  «<mark>组件</mark>通用属性请参见<mark>组件</mark>通用说明。»  - 标识:锚点的唯一标识,用于跳转链接。  事件  锚点<mark>组件</mark>不支持设置事件。  样式  样式说明请参见<mark>组件</mark>通用说明。  注意事项  - 锚点<mark>组件</mark>默认为空容器,支持拖入其他<mark>组件</mark>,不影响锚点正常跳转功能。  - 锚点<mark>组件</mark>发布后不直接显示。  案例  功能需求  搭配目录<mark>组件</mark>实现锚点指定位置的跳转。  操作步骤  1.","highlightedTitle":"锚点"},{"esId":"2614959180559616","highlightedContent":"| 事件名   | 触发条件                 |  | -------- | ------------------------ |  | 获得焦点 | 多行<mark>组件</mark>输入框聚焦时触发 |  | 失去焦点 | 多行<mark>组件</mark>输入框失焦时触发 |  - 支持输入<mark>组件</mark>常见的<mark>组件</mark>事件:输入前,改变后,清空后。","highlightedTitle":"单行输入"},{"esId":"2614959179961600","highlightedContent":"<mark>组件</mark>通用说明  每个<mark>组件</mark>都包含属性、事件和样式。其中大部分功能以及设置方式相同,本节对<mark>组件</mark>的通用属性做详细说明。  属性  基础信息  - <mark>组件</mark>名称:由字母、数字和下划线组成,用于在表达式中引用、权限上报等场景。  - 是否控制权限:可根据角色设置权限,对无权限的角色的用户隐藏该<mark>组件</mark>,设置权限前,必须先设置<mark>组件</mark>名称。","highlightedTitle":"组件通用说明"},{"esId":"2614959177340160","highlightedContent":"徽章中可自定义添加<mark>组件</mark>。  <mark>组件</mark>说明  属性  «<mark>组件</mark>通用属性请参见<mark>组件</mark>通用说明。»  - 值:当前提醒消息条数,支持动态绑定。  - 最大值:提醒消息的最大值,超过最大值将不再显示准确的数字,用最大值+代替,如99+。  - 插入右上角:开启时提醒角标位置显示在右上角,关闭时提醒角标显示在<mark>组件</mark>右侧。  事件  徽章<mark>组件</mark>不支持设置事件。  样式  样式说明请参见<mark>组件</mark>通用说明。","highlightedTitle":"徽章"},{"esId":"2614959178069248","highlightedContent":"目录  支持通过目录<mark>组件</mark>来标识长页面中当前所处的位置,以及页面跳转等功能。  <mark>组件</mark>说明  属性  «<mark>组件</mark>通用属性请参见<mark>组件</mark>通用说明。»  目录<mark>组件</mark>  - 选中值:通过<mark>组件</mark>进行选择后,最终选中的值,支持双向绑定到变量。  目录节点  - 选项值:集合的元素类型中,用于标识选中值的属性。  - 链接类型:支持页面跳转、普通链接、下载链接。  - 链接地址:链接的详细地址。","highlightedTitle":"目录"}];
        }
      }, 0)
    },
    onInput(e) {
      console.log('onInput', e)
      this.fetchData(e)
    },
    onChange(e) {
      console.log('onChange', e)
    }
  }
}
</script>

API

Props/Attrs

| Prop/Attr | Type | Options | Default | Description | | --------- | ---- | ------- | ------- | ----------- | | value.sync, v-model | String | | | 输入的值 | | data-source | Array<Item> | | | 搜索结果列表数据 | | data-schema | schema | | | 选择器每一行的数据类型 | | text-field | string | | 'text' | 显示结果项标题字段的属性 | | description-field | string | | | 用于显示结果项描述字段的属性 | | loading | boolean | | false | 用于显示加载状态 | | align | string | [object Object][object Object] | 'left' | undefined | | clearable | boolean | | | 开启并在输入框有内容时会显示清除按钮 | | placeholder | string | | | 为空时的提示文本 | | maxlength | number | | | | | autofocus | boolean | | false | 是否自动获取焦点 | | readonly | boolean | | false | | | disabled | boolean | | false | | | width | string | [object Object][object Object][object Object][object Object][object Object][object Object][object Object] | 'normal' | 设置单行输入框宽度大小 | | height | string | [object Object][object Object][object Object][object Object][object Object][object Object][object Object] | 'normal' | 设置单行输入框高度大小 | | prefix | icon | | '' | | | suffix | icon | | '' | | | border-radius | string | | '0px' | undefined |

Events

@select

选择结果时触发

| Param | Type | Description | | ----- | ---- | ----------- | | $event.item | object | 选择项相关对象 |

@before-input

输入前触发。可以在这个阶段阻止输入,或者修改输入的值 $event.value

| Param | Type | Description | | ----- | ---- | ----------- | | $event | object | 自定义事件对象 | | $event.oldValue | string | 旧的值 | | $event.value | string | 输入框的值 | | $event.preventDefault | Function | 阻止输入流程 |

@input

输入时触发。

| Param | Type | Description | | ----- | ---- | ----------- | | $event | string | 输入框的值 |

@change

值变化时触发。(注意:与原生事件不同)

| Param | Type | Description | | ----- | ---- | ----------- | | $event | object | 自定义事件对象 | | $event.value | string | 改变后的值 | | $event.oldValue | string | 旧的值 |

@focus

获得焦点时触发。

| Param | Type | Description | | ----- | ---- | ----------- | | $event | FocusEvent | 原生事件对象 |

@blur

失去焦点时触发。

| Param | Type | Description | | ----- | ---- | ----------- | | $event | FocusEvent | 原生事件对象 |

@before-clear

清空前触发。

| Param | Type | Description | | ----- | ---- | ----------- | | $event | object | 自定义事件对象 | | $event.value | string | 清空后的值 | | $event.oldValue | string | 待清空的值 | | $event.preventDefault | Function | 阻止清空流程 |

@clear

清空后触发。

| Param | Type | Description | | ----- | ---- | ----------- | | $event | object | 自定义事件对象 | | $event.value | string | 清空后的值 | | $event.oldValue | string | 旧的值 |

@click-prefix

点击前缀图标后触发

| Param | Type | Description | | ----- | ---- | ----------- | | $event | object | 鼠标事件对象 |

@click-suffix

点击后缀图标后触发

| Param | Type | Description | | ----- | ---- | ----------- | | $event | object | 鼠标事件对象 |

Methods

focus()

让输入框获取焦点。

| Param | Type | Default | Description | | ----- | ---- | ------- | ----------- |

blur()

让输入框失去焦点。

| Param | Type | Default | Description | | ----- | ---- | ------- | ----------- |

clear()

清空输入框。

| Param | Type | Default | Description | | ----- | ---- | ------- | ----------- |