liquidmetal

:sweat_drops::metal: A mimetic poly-alloy of the Quicksilver scoring algorithm, essentially LiquidMetal.

Github星跟蹤圖

LiquidMetal

A mimetic poly-alloy of the Quicksilver
scoring algorithm, essentially LiquidMetal. </Schwarzenegger Voice>

Flex matching short abbreviations against longer strings is a boon in
productivity for typists. Applications like
Quicksilver, Alfred,
LaunchBar, and
Launchy have made this method of keyboard entry a
popular one. It's time to bring this same functionality to web controls.
LiquidMetal makes scoring long strings against abbreviations easy.

Usage

Include the library:

<script src="liquidmetal.js" type="text/javascript"></script>

Score any string against an abbreviation:

LiquidMetal.score("FooBar",  "foo")   //=> 0.950
LiquidMetal.score("FooBar",  "fb")    //=> 0.917
LiquidMetal.score("Foo Bar", "fb")    //=> 0.929
LiquidMetal.score("Foo Bar", "baz")   //=> 0.0
LiquidMetal.score("Foo Bar", "")      //=> 0.8

All scores fall between a range of 0.0 (no match) to 1.0 (perfect match).

Inspired By

Why?

  • To satisfy my own requirements for the
    jquery.flexselect plugin
  • The Quicksilver algorithm doesn't give proper weight to abbreviations that
    match the first character of the scored string.
  • The Quicksilver algorithm is extremely slow for certain length
    string/abbreviation combinations because of its use of recursion. While
    slightly slower for shorter length string/abbreviation combinations,
    LiquidMetal outperforms the Quicksilver algorithm by orders of magnitude under
    other conditions.
  • The javascript version of the Quicksilver algorithm (Quicksilver.js) is case
    sensitive and doesn't give added weight to camel case strings; whereas,
    LiquidMetal is case insensitive and does give added weight to uppercase
    letters in camel case strings.

Todo

  • More tests
  • Consider tweaking the scores for "trailing" characters
  • Improve implementation of highest score matching (LiquidMetal
    currently returns the highest scoring match for an abbreviation,
    but is inefficient)
  • See if it's possible to tune the performance further

Author

Ryan McGeary (@rmm5t)

License

MIT License

主要指標

概覽
名稱與所有者rmm5t/liquidmetal
主編程語言JavaScript
編程語言JavaScript (語言數: 2)
平台
許可證MIT License
所有者活动
創建於2009-02-06 00:16:49
推送於2020-06-17 02:10:02
最后一次提交2020-06-16 20:09:49
發布數7
最新版本名稱v1.3.0 (發布於 )
第一版名稱v0.1 (發布於 )
用户参与
星數295
關注者數8
派生數24
提交數56
已啟用問題?
問題數6
打開的問題數1
拉請求數4
打開的拉請求數0
關閉的拉請求數0
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?