Classes and regex
Classes
method chaining
You can chain methods together on your class by returning this
inside every method.
class DateClass {
public chain1() {
console.log("chain1");
return this;
}
public chain2() {
console.log("chain2");
return this;
}
public chain3() {
console.log("chain3");
return this;
}
}
const date = new DateClass();
date.chain1().chain2().chain3();
Static inheritance
Classes inherit all static methods and properties from parent classes. You can take further advantage of this by using super
for overriding static properties and methods from the parent.
class Parent {
static attributes = ["hello"]
}
class Child extends Parent {
static attributes = [...super.attributes, "dog"]
}
console.log(Child.attributes) // ["hello", "dog"]
Regex
Regex In JS
Regex data type
You can specify a regex data type by typing in two forward slashes and putting all the regex in between them.
- Regular expression flags goes after the slash forward slash.
const r1 = /^big.*cheese$/ig
string methods
string.match(regex: RegExp)
: tests the passed in regex on the string. Returns an array of the capture groups. Returnsstring[]
string.search(regex: regExp)
: returns the index of the first match in the string. Returnsnumber
string.split(regex: regExp)
: Splits on the regex matc, returns string array. Returnsstring[]
string.replace(regex: RegExp, newText : string)
: replaces every match in the string with the new text specified.
regex method
regex.test(string)
: tests the passed in string against the regex. Returns a boolean of whether it passed or not.regex.exec(string)
: returns an array of matches of the capture groups.
Regex Theory
Regex Flags
Regex flags are what you put after the final forward slash. Here are the different useful flags:
g
: global. Does not return after first match.i
: case insensitivem
: multiline
Character sets
Character sets are thing things you put in between brackets like [A-Z]
. Metacharacters are special escaped sequences that represent something else, like how \d
represents a digit.
- Putting a
^
at the first character of a character set excludes everything in that character set. - Characters you need to escape with a backslash:
-
,^
,\
,]
Basic metacharacters
\d
: represents [0-9]\w
: represents any alphanumeric character\s
: represents whitespace
There are also the negative equivalents you get by putting the ^
at the fornt of the character set.
\D
: represents all characters not\d
, all non-numeric.\W
: represents all characters not\w
, all non-alphanumeric.\S
: represents all characters not\s
, all non-whitespace
Repetition
Greediness is what causes regex to naturally match the entire line, and then backtrack to match the characters it needs to match.
- greedy regex matches as much as it possibly can.
- Regex expressions are naturally greedy. We need to use a
?
to make them lazy.
Laziness is the opposite of greediness. We can make regex lazy by putting a ?
after a repetition character, like *?
and +?
.
- Lazy regex matches as little as possible
Specific repeition characters
{3}
: match exactly three times{3,6}
: match between 3 to 6 times{3,}
: match at least 3 times*
: match 0 or more times+
: match 1 or more times
Lazy repetition
+?
: match at least one character, or as few characters as possible of the preceding token*?
: match at least zero characters, or as few characters as possible of the preceding token??
: matches 0 characters
Anchors + Word boundaries
When we use anchors, we need to use the multiline flag to let anchors work on each line.
^
: anchors at the start$
: anchors at the end
Word boundaries
\b
: specifes a word boundary, a non-word character.\B
: specifies a word character, bounding a word between an alphanumeric character.
Examples
\bplan\b
: specifies that we want the word "plan" by itself, where you match a non-word character, then the word, and then another non-word character.\bplan\B
: specifies that we need word characters after "plan" but not before, like "planning"
Matching beginning and ending of string
\A
: matches beginning of the string.- The
^
in multiline flag mode will match the beginning of each line in a string. - The
\A
will only match the beginning of a string, ignoring the fact that the string is multiline.
- The
\Z
: matches end of the string.\Z
matches only at the end of the string, even when the string is multiline.
Capturing groups
Unnamed capturing group references
Capturing groups do not grab the pattern. They grab the natural text that matches the pattern in a string.
Refer back to capturing groups by a backslash and then a number, like \1
to refer the first capturing group.
- group back references only what is captured, not the pattern. Only use group back references if you want the text to be the exact same as what was captured.
non-capturing group
Put a ?:
at the start of the group, indicating you don't want this to be a capturing group.
For example, (?:hello)
groups the "hello" text but does not capture it.
naming capturing groups
To name a capture group, use the ?<nameOfGroup>
syntax.
The group back reference for named capturing groups starts with a \k
, to indicate named references, and is like this: \k<nameOfGroup>
Lookahead groups
- Lookahead groups start with
?=
, and define match patterns but don't consume any characters. - Negative lookahead groups are the opposite of lookahead groups, and start with
?!
. - Lookbehind groups start with
?<=
, and at the point in the pattern, it looks behind for a match pattern you specify. - Negative lookbehind groups start with
?<!
, and is the opposite of a lookbehind.
const text = "I have $59 but not 59 hoes"
const regex = /(?<=\$)\d+/g
console.log(text.match(regex)) // matches $59
Capturing groups JS
Using capturing groups allows us to parse the captured data in javascript. We can get data from capturing groups by using the regex.exec(str)
method, which returns an array of matches.
All capturing group matches start at index [1]
, since the full string input will always be the first match.
const string = "1-2-3"
const regex = /(\d)-(\d)-(\d)/g
// returns ["1-2-3","1","2","3"], so 4 groups. The first group is always the entire match
const match_arr = regex.exec(string)