voca

The ultimate JavaScript string library

Github星跟蹤圖

Voca JavaScript library logo

travis build
code coverage
npm package

Voca is a JavaScript library for manipulating strings. https://vocajs.com

v.camelCase('bird flight');              // => 'birdFlight'
v.sprintf('%s costs $%.2f', 'Tea', 1.5); // => 'Tea costs $1.50'
v.slugify('What a wonderful world');     // => 'what-a-wonderful-world'

The Voca library offers helpful functions to make string manipulations comfortable: change case, trim, pad, slugify,
latinise, sprintf'y, truncate, escape
and much more. The modular design allows to load the entire library, or
individual functions to minimize the application builds. The library is fully tested, well documented and long-term supported.

Features

  • Provides the complete set of functions to manipulate, chop, format, escape and query strings
  • Includes detailed, easy to read and searchable documentation
  • Supports a wide range of environments: Node.js 0.10+, Chrome, Firefox, Safari 7+, Edge 13+, IE 9+
  • 100% code coverage
  • No dependencies

Documentation

See the complete documentation at https://vocajs.com

Usage

Voca can be used in various environments.

Node.js, Rollup, Webpack, Browserify

Voca JavaScript library supports Node.js, Rollup, Webpack, Browserify

Install the library with npm into your local modules directory:

npm install voca

CommonJS modules

Then in your application require the entire library:

const v = require('voca');
v.trim(' Hello World! ');            // => 'Hello World'
v.sprintf('%d red %s', 3, 'apples'); // => '3 red apples'

Or require individual functions:

const words = require('voca/words');
const slugify = require('voca/slugify');
words('welcome to Earth'); // => ['welcome', 'to', 'Earth']
slugify('caffé latté');    // => 'caffe-latte'

ES2015 modules

Voca is compatible with ES2015 modules to import the entire library:

import voca from 'voca';
voca.kebabCase('goodbye blue sky'); // => 'goodbye-blue-sky'

Or import individual functions:

import last from 'voca/last';
last('sun rises', 5); // => 'rises'

Browser

Voca JavaScript library supports Chrome, Firefox, Safari, Edge, Internet Explorer

Load the UMD builds directly into browser's web page:

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

Then a global variable v is exposed for the entire library:

<script type="text/javascript">
  v.last('wonderful world', 5); // => 'world'
</script>

Functions, Manipulate, Query, Chop, Case, Index, :-----------------------------------, :-----------------------------, :-----------------------------------, :-----------------------------, :------------------------------, v.insert, v.endsWith, v.charAt, v.camelCase, v.indexOf, v.latinise, v.includes, v.codePointAt, v.capitalize, v.lastIndexOf, v.pad, v.isAlpha, v.first, v.decapitalize, v.search, v.padLeft, v.isAlphaDigit, v.graphemeAt, v.kebabCase, Escape, v.padRight, v.isBlank, v.last, v.lowerCase, v.escapeHtml, v.repeat, v.isDigit, v.prune, v.snakeCase, v.escapeRegExp, v.replace, v.isEmpty, v.slice, v.swapCase, v.unescapeHtml, v.replaceAll, v.isLowerCase, v.substr, v.titleCase, Strip, v.reverse, v.isNumeric, v.substring, v.upperCase, v.stripBom, v.reverseGrapheme, v.isString, v.truncate, Split, v.stripTags, v.slugify, v.isUpperCase, Count, v.chars, v.splice, v.matches, v.count, v.codePoints, v.tr, v.startsWith, v.countGraphemes, v.graphemes, v.trim, Format, v.countSubstrings, v.split, v.trimLeft, v.sprintf, v.countWhere, v.words, v.trimRight, v.vprintf, v.countWords, v.wordWrap, ## Bug reports

For bug reports, documentation typos or feature requests feel free to create an issue.
Please make sure that the same problem wasn't reported already.

For general usage questions please ask on StackOverflow.

Contributing

Contribution is welcome!

  • Create a pull request containing bug fixes or new features. Include unit tests and keep the code coverage report near 100% ?
  • Propose new functions, improvements, better documentation

See more details in Contributing guide.

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

Author, Dmitri Pavlutin, :-:, Dmitri Pavlutin, Personal blog, Email

License

Licensed under MIT

主要指標

概覽
名稱與所有者panzerdp/voca
主編程語言JavaScript
編程語言JavaScript (語言數: 2)
平台
許可證MIT License
所有者活动
創建於2016-03-23 15:10:11
推送於2023-08-01 14:18:16
最后一次提交2023-05-17 10:47:43
發布數11
最新版本名稱v1.4.0 (發布於 )
第一版名稱1.0.0-alpha.0 (發布於 )
用户参与
星數3.6k
關注者數53
派生數139
提交數550
已啟用問題?
問題數49
打開的問題數12
拉請求數6
打開的拉請求數3
關閉的拉請求數7
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?