2.0.0 • Published 5 months ago

mdurl v2.0.0

Weekly downloads
3,192,774
License
MIT
Repository
github
Last release
5 months 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-2148owt-client-javascriptparvan_componentsparvan_reactjs_componentspf-docsmyui5librarychenmyui5librarymobomyreuselibraryzona-xzjx-markdown-it@cdk8s-extensions/argo-rollout@docus/core@docus/mdc@docus/mdc-edge@cosmicmedia/markdown-it@cnblogs/markdown-it@darren-valent/cdk-ec2-key-paircanvaslib_hlzhihu-markdown@breakaway/theme-patternfly-org@breakaway/documentation-framework@bitsler/markdown-it@buganto/client@byloth/vue-content@blkmarketco/components-library@bloodf/nuxt-content@gerhobbelt/markdown-itvue3-google-login-with-statetyped-mdast-util-to-hasturl-unshortvremark-parsecliptool_hl@hanye9895/markdown-itcordova-plugin-amplify-paycordova-plugin-amplify-paymentcoderteq_financementorbox@globalbrain/markdown-itcommonmark@markflowy/editorfn-lib-examplezzzxxxyyy321123react-form-component-libraryreact-native-linkifyreact-native-hyperlinktingzi-vuepresstldrawligninsequelcomponentrsql-jstheme-patternfly-orgsvelte-component-libstorybook-addon-markdown-docsstemcstudio-markdownuni-navvite-plugin-md-plusvelppdesign-system-fitbank-450docute-markdown-it@lego-js/testscineverse-apiclient-javascriptdaodao-theme-test-patternfly-org@om-tlh/markdown-it@nuxt/content-edge@nuxt/content@object-studio/react-native-web@open-wc/demoing-storybookgrape-web@mdoc/mdast-util-to-hast@mattermost/commonmarkflavormark@minodisk/medmd@minmaxindustries/mws-sdk@molgenis/rsql@molgenis/rsql-js@molgenis-ui/core-ui@molgenis/core-uigassefalsgassefals-2discordjs-con-selfcustompackagetestvarthinidiscord.js-bycon@realzh/rz-markdown-it@parkcedar/leaflet@rdx-js/rdx@rstacruz/pnpm@podlubnaja/ui-kitcoffeenode-markdown-it@hackmd/markdown-itdynamics-contracts-xenefti-galeri@patternfly/documentation-framework@sharshar/date-lib@shivarajapple/first-library@skeetboothppq/component-library@farnabaz/content@farnabaz/mdc
2.0.0

5 months ago

1.0.1

9 years ago

1.0.0

9 years ago

0.0.1

9 years ago