2.0.0 • Published 2 years ago

mdurl v2.0.0

Weekly downloads
3,192,774
License
MIT
Repository
github
Last release
2 years ago

mdurl

CI NPM version

URL utilities for markdown-it parser.

API

.encode(str , exclude, keepEncoded) -> String

Percent-encode a string, avoiding double encoding. Don't touch /a-zA-Z0-9/ + excluded chars + /%[a-fA-F0-9]{2}/ (if not disabled). Broken surrorates are replaced with U+FFFD.

Params:

  • str - input string.
  • exclude - optional, ;/?:@&=+$,-_.!~*'()#. Additional chars to keep intact (except /a-zA-Z0-9/).
  • keepEncoded - optional, true. By default it skips already encoded sequences (/%[a-fA-F0-9]{2}/). If set to false, % will be encoded.

encode.defaultChars, encode.componentChars

You can use these constants as second argument to encode function.

  • encode.defaultChars is the same exclude set as in the standard encodeURI() function
  • encode.componentChars is the same exclude set as in the encodeURIComponent() function

For example, encode('something', encode.componentChars, true) is roughly the equivalent of the encodeURIComponent() function (except encode() doesn't throw).

.decode(str , exclude) -> String

Decode percent-encoded string. Invalid percent-encoded sequences (e.g. %2G) are left as is. Invalid UTF-8 characters are replaced with U+FFFD.

Params:

  • str - input string.
  • exclude - set of characters to leave encoded, optional, ;/?:@&=+$,#.

decode.defaultChars, decode.componentChars

You can use these constants as second argument to decode function.

  • decode.defaultChars is the same exclude set as in the standard decodeURI() function
  • decode.componentChars is the same exclude set as in the decodeURIComponent() function

For example, decode('something', decode.defaultChars) has the same behavior as decodeURI('something') on a correctly encoded input.

.parse(url, slashesDenoteHost) -> urlObs

Parse url string. Similar to node's url.parse, but without any normalizations and query string parse.

  • url - input url (string)
  • slashesDenoteHost - if url starts with //, expect a hostname after it. Optional, false.

Result (hash):

  • protocol
  • slashes
  • auth
  • port
  • hostname
  • hash
  • search
  • pathname

Difference with node's url:

  1. No leading slash in paths, e.g. in url.parse('http://foo?bar') pathname is , not /
  2. Backslashes are not replaced with slashes, so http:\\example.org\ is treated like a relative path
  3. Trailing colon is treated like a part of the path, i.e. in http://example.org:foo pathname is :foo
  4. Nothing is URL-encoded in the resulting object, (in joyent/node some chars in auth and paths are encoded)
  5. url.parse() does not have parseQueryString argument
  6. Removed extraneous result properties: host, path, query, etc., which can be constructed using other parts of the url.

.format(urlObject)

Format an object previously obtained with .parse() function. Similar to node's url.format.

License

MIT

markdown-it@ctxhou/markdown-it@sup39/markdown-it@infinitebrahmanuniverse/nolb-mdu@saaspe/components@everything-registry/sub-chunk-2148storybook-addon-markdown-docssvelte-component-libvremark-parsevite-plugin-md-plusvelppjs-slate-markdown-serializerlystable-commonmarkmarkdown-it-hyperzmarkdown-it-faxesmarkdown-it-for-mdvcmarkdown-themmarkdown-to-bbcodemarkdown-it-weflexmarkdown-it-zqmarkdown-it-projectphilmarkdown-it-driftmarkdown-it-esmmarkdown-it-coldmarkmathpix-markdown-itm2m-chartjs-plugin-crosshairm-markdown-itloading-animatedmd-markdown-parsermdmathmdast-util-to-hast-backport@vuepress/markdown@tonysusi/vapid@topwrite/common@topwrite/core@voraciousdev/nuxt3-content@vitali_shcherbina/styled-lib@zalastax/nolb-mdu@zeroby0/markdown-itargdown-parserappcharge-checkout@hanye9895/markdown-it@hackmd/markdown-itzzzxxxyyy321123stemcstudio-markdowntyped-mdast-util-to-hasttingzi-vuepresstheme-patternfly-orgtldrawligninzhihu-markdownzona-xvue3-google-login-with-stateuni-navurl-unshortzjx-markdown-it@lego-js/testsminimauscgamecocksandstormminttown_pf_communitymicrojammyui5librarymobomyreuselibrarymyui5librarychenowt-client-javascriptparvan_componentsparvan_reactjs_componentspanzx-storereact-native-linkifyreact-native-hyperlinkrsql-jssandai-corereact-native-nayanreact-form-component-librarysequelcomponentpf-docsshowgallerygrape-web@parkcedar/leaflet@nuxt/content-edge@object-studio/react-native-web@om-tlh/markdown-it@open-wc/demoing-storybook@patternfly/documentation-framework@hoyii/markdown2html@globalbrain/markdown-it@gerhobbelt/markdown-it@farnabaz/content@farnabaz/nuxt-mdc@fanfix/nestjs-firebase@podlubnaja/ui-kit@peterloveshim/common-utilfn-lib-examplegassefalsgassefals-2@shivarajapple/first-library@sharshar/date-lib@starzkg/vuepress-plugin-markdown-enhancedocute-markdown-itdynamics-contracts-xenefti-galeriflavormark
2.0.0

2 years ago

1.0.1

10 years ago

1.0.0

11 years ago

0.0.1

11 years ago