Package Exports
- easy-replace
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (easy-replace) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
easy-replace
Replace strings with optional lookarounds, but without regexes
Table of Contents
Install
npm i easy-replace// consume via CommonJS require:
const er = require("easy-replace");
// or as native ES Module:
import er from "easy-replace";Here's what you'll get:
| Type | Key in package.json | Path | Size | 
|---|---|---|---|
| Main export - CommonJS version, transpiled to ES5, contains requireandmodule.exports | main | dist/easy-replace.cjs.js | 13 KB | 
| ES module build that Webpack/Rollup understands. Untranspiled ES6 code with import/export. | module | dist/easy-replace.esm.js | 13 KB | 
| UMD build for browsers, transpiled, minified, containing iife's and has all dependencies baked-in | browser | dist/easy-replace.umd.js | 20 KB | 
Usage
The ideal use case for easy-replace is when you need complex lookarounds, such as "replace this only when there is something on the left, but also, if there's some things on the right, include them too, yet there can't be such and such on the right". Yes, you could solve this using a regex (if it exists at all), but it's faster to skip regex solutions and simply use this library.
API
er(source_string, options_object, replacement_string);API - Input
| Input argument | Type | Obligatory? | Description | 
|---|---|---|---|
| source_string | String | yes | Original string | 
| options_object | Plain Object | yes | Settings | 
| replacement_string | String | no | Replace all the findings with this. If missing, library runs on delete-only mode, it won't replace, just delete. | 
Options object:
| Options object's key | Type | Obligatory? | Description | 
|---|---|---|---|
| { | |||
| leftOutsideNot | String/Array of strings | no | Equivalent of regex negative lookbehind. This/these string(s) must not be present to the left of searchFor(plus any "maybe's" strings, see below), in order forsearchForto be counted as "found". This input's contents are not replaced/deleted. | 
| leftOutside | String/Array of strings | no | Equivalent of regex positive lookbehind. This/these string(s) must be present to the left of searchFor(plus any "maybe's" strings, see below), in order forsearchForto be counted as "found". This input's contents are not replaced/deleted. | 
| leftMaybe | String/Array | no | If this is present on the left side of the searchFor, replace/delete it together withsearchFor, but don't fret if it's not found. | 
| searchFor | String only | yes | The keyword to look for in the source_string | 
| rightMaybe | String/Array of strings | no | If this is present on the right side of the searchFor, replace/delete it together withsearchFor, but don't fret if it's not found. | 
| rightOutside | String/Array of strings | no | Equivalent of regex positive lookahead. This/these string(s) must be present to the right of searchFor(plus any "maybe's" strings, see higher), in order forsearchForto be counted as "found". This input's contents are not replaced/deleted. | 
| rightOutsideNot | String/Array of strings | no | Equivalent of regex negative lookahead. This/these string(s) must not be present to the right of searchFor(plus any "maybe's" strings, see higher), in order forsearchForto be counted as "found". This input's contents are not replaced/deleted. | 
| i | Plain object | no | Each key mentioned above can be set to a Boolean true/falseto optionally be case-insensitive. Same thing asiflag in regexes. | 
| } | 
API - Output
| Type | Description | 
|---|---|
| String | String with things replaced | 
Examples
Simple replace:
- Example replacement recipe in words — replace all instances of - xwith- 🦄.
- Solution using this library:: 
const er = require("easy-replace");
er(
  "a x c x d",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: "",
    searchFor: "x",
    rightMaybe: "",
    rightOutside: "",
    rightOutsideNot: ""
  },
  "🦄"
);
//=> 'a 🦄 c 🦄 d'Case insensitive setting — set each and every key you want to ignore the case via opts.i:
var er = require("easy-replace");
er(
  "a X c x d",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: "",
    searchFor: "x",
    rightMaybe: "",
    rightOutside: "",
    rightOutsideNot: "",
    i: {
      searchFor: true
    }
  },
  "🦄"
);
//=> 'a 🦄 c 🦄 d'"Maybes" — optional surrounding strings to be replaced as well
- Example replacement recipe in words — Replace all instances of - i. If there are- 🐴or- 🦄characters on the left, count them as part of found- iand replace together as one thing. If there are- 🐴or- 🦄characters on the right, count them as part of found- iand replace together as one thing.
- Solution using this library:: 
var er = require("easy-replace");
er(
  "🐴i🦄 🐴i i🦄 i",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: ["🐴", "🦄"],
    searchFor: "i",
    rightMaybe: ["🐴", "🦄"],
    rightOutside: "",
    rightOutsideNot: ""
  },
  "x"
);
//=> 'x x x x'By the way, notice, how the values can be strings or arrays! The easy-replace doesn't accept array only for searchFor values — create a loop from the outside of this library, then call this library many times if you want to search for multiple values.
Case-insensitive setting will cover more surroundings' cases:
var er = require("easy-replace");
er(
  "Ai ib Aib i",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: ["a", "z"],
    searchFor: "i",
    rightMaybe: ["y", "b"],
    rightOutside: "",
    rightOutsideNot: "",
    i: {
      leftMaybe: true
    }
  },
  "x"
);
//=> 'x x x x'Negative lookahead - if you want to match something not followed by something else
- Example replacement recipe in words — Replace all instances of - 🦄, but only ones that don't have- cor- don the right.
- Solution using this library:: 
var er = require("easy-replace");
er(
  "a🦄c x🦄x",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: "",
    searchFor: "🦄",
    rightMaybe: "",
    rightOutside: "",
    rightOutsideNot: ["c", "d"]
  },
  "🐴"
);
//=> 'a🦄c x🐴x'Case insensitive setting will narrow-down the amount of findings/replacements:
var er = require("easy-replace");
er(
  "a🦄C x🦄x",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: "",
    searchFor: "🦄",
    rightMaybe: "",
    rightOutside: "",
    rightOutsideNot: ["c", "d"],
    i: {
      rightOutsideNot: true
    }
  },
  "🐴"
);
//=> 'a🦄c x🐴x'Positive lookbehind - if you want to match something that is preceded by something else
For example, search for space characters that have another space right to their left, and delete them
- Example replacement recipe in words — Replace all occurencies of space character, but only those that have another space character in front of them. 
- Solution using this library:: 
var er = require("easy-replace");
er(
  "zzzzz  zzzzzz zzzzzz",
  {
    leftOutsideNot: "",
    leftOutside: " ", // <- space
    leftMaybe: "",
    searchFor: " ", // <- space
    rightMaybe: "",
    rightOutside: "",
    rightOutsideNot: ""
  },
  "" // <- empty string
);
//=> 'zzzzz zzzzzz zzzzzz'Negative lookbehind - if you want to match something that is NOT preceded by something else
For example, our <br /> sometimes look like <br/>. Replace all occurencies of /> with {{space character}}/> (disregard curly braces, it's only to make it more visible here) if they are not preceded with space already:
- Example replacement recipe in words — Add missing spaces before closing slashes on tags. Do not add spaces where they exist already. 
- Solution using this library:: 
var er = require("easy-replace");
er(
  "<br /><br/><br />",
  {
    leftOutsideNot: " ",
    leftOutside: "",
    leftMaybe: "",
    searchFor: "/>",
    rightMaybe: "",
    rightOutside: "",
    rightOutsideNot: ""
  },
  " />"
);
//=> '<br /><br /><br />'Real life scenario
- Example replacement recipe in words — Add a missing semicolon and/or ampersand on -  , but only where they are missing.
- Solution using this library:: 
var er = require("easy-replace");
er(
  "  nbsp   nbsp;",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: "&",
    searchFor: "nbsp",
    rightMaybe: ";",
    rightOutside: "",
    rightOutsideNot: ""
  },
  " "
);
//=> '       'If you want to cover cases of random letter capitalisation of n, b, s and p, just set case-insensitive flag for searchFor:
var er = require("easy-replace");
er(
  "&nBsp; NBsp &nbSP NbsP;",
  {
    leftOutsideNot: "",
    leftOutside: "",
    leftMaybe: "&",
    searchFor: "nbsp",
    rightMaybe: ";",
    rightOutside: "",
    rightOutsideNot: "",
    i: {
      searchFor: true
    }
  },
  " "
);
//=> '       'Rationale
Positive lookbehinds and negative lookbehinds are not supported in native JavaScript (at least in what we count as "classic" JavaScript, not ES2030 or something). If you gonna use a library for string replacement, better use one with "easy" in its name.
Did I mention that easy-replace is also astral-character-friendly? As you noticed in the examples above, it accepts emoji perfectly fine (and AVA tests prove this).
It's also impossible to cause an infinite loop on this library (see tests 8.1-8.6).
easy-replace is also friendly if any input is of a number type — numbers are converted and replaced string is returned in string type (see test 10.8). That's an extra convenience.
Options object is fool-proof — you can omit keys or pass non-existing ones or pass non-string type variables — if the options key matches, it's first turned into string. You can even omit any or all of the inputs — library will return an empty string (see tests 9.1–9.6).
Same with replacment — empty, null, boolean or undefined are accepted and interpreted as a request to delete any results found. There's no replacement, only deletion in such case (see tests 10.1–10.7).
Contributing
- If you want a new feature in this package or you would like us to change some of its functionality, raise an issue on this repo. 
- If you tried to use this library but it misbehaves, or you need advice setting it up, and its readme doesn't make sense, just document it and raise an issue on this repo. 
- If you would like to add or change some features, just fork it, hack away, and file a pull request. We'll do our best to merge it quickly. Prettier is enabled, so you don't need to worry about the code style. 
Licence
MIT License (MIT)
Copyright © 2018 Codsen Ltd, Roy Revelt