Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
jquery.urianchor
Advanced tools
uriAnchor jQuery plugin - SPA URI management made simple. Use this plugin to manage dependent and independent parameters in the hash fragment of the URI. It has been designed and updated over five commercial SPA projects and is featured in the book [Sing
A jQuery plugin for management of the URI hash component.
Use this plugin to manage dependent and independent variables in the hash fragment of the URI. It has been designed and updated over five commercial SPA projects and is featured in the book Single page web applications - JavaScript end-to-end. It provides the capability to make the URI fragment your application state API. Bookmarks, browser history, the back button, and the forward button can all be made to act as the user expects while enabling you to update only the part of the page that has changed.
The plugin, used with a few other well-chosen tools, form a fantastic basis for a lean, easy to use SPA architecture as detailed in the the book(http://manning.com/mikowski). Here are the recommended tools:
This suite of tools has all the capabilities of modern framework libraries but, when used correctly, can vastly improve flexibility and testability. It leverages jQuery's excellent built-in tools instead of ignoring them!
2013 Michael S. Mikowski (mike[dot]mikowski[at]gmail[dotcom])
Dual licensed under the MIT or GPL Version 2 http://jquery.org/license
These are the first releases registered with jQuery plugins.
Documentation updates, minor bug fixes.
Sets Anchor component of the URI from a Map (The Anchor component is also known as the 'hash fragment' or 'bookmark component')
Arguments are positional:
anchor_map
) : The map to be encoded to the URI anchoroption_map
) : A map of optionsreplace_flag
) : A boolean flag. When true, the method replaces the URI so that prior URI is not entered into the browser historyExpects the document.location browser object
none
boolean: true on success, false on failure
none
The first positional argument, anchor_map
, may be a simple map:
$.uriAnchor.setAnchor({
page : 'profile',
slider : 'confirm',
color : 'red'
});
This changes the URI anchor to:
#!page=profile&slider=confirm&color=red
All these arguments are independent, that is, they can vary independent of each other. We also support dependent values - values that depend on others.
An independent argument key has no _
prefix. The same key name,
prefixed by an _
, holds the arguments that are dependent on
an independent argument. The dependent key always points
to a map. Consider:
$.uriAnchor.setAnchor({
page : 'profile',
_page : {
uname : 'wendy',
online : 'today'
}
});
This changes the URI Anchor to:
#!page=profile:uname,wendy|online,today
Only independent keys and their matching dependent keys are
processed. All other keys are ignored. Importantly, this includes
keys of the form _s_<key>
( e.g. _s_page
) returned by makeAnchorMap
Setting a more complex anchor map is illustrated below:
$.uriAnchor.setAnchor({
page : 'profile',
_page : {
uname : 'wendy',
online : 'today'
},
slider : 'confirm',
_slider : {
text : 'hello',
pretty : false
},
color : 'red'
});
This sets the URI Anchor to:
#!page=profile:uname,wendy|online,today&slider=confirm:text,hello\
|pretty,false&color=red
Options: The second positional argument tp this method, option_map
,
provides a number of options for delimiters:
delimit_char
: Delimiter between independent args. Default is &
.delimit_kv_char
: Delimiter between key and value of independent args. Default is =
.sub_delimit_char
: Delimiter between independent and dependent args. Defaults is :
.dep_delimit_char
: Delimiter between key-value pairs in dependent args. Default is |
.dep_kv_delimit_char
: Delimiter between key and value of dependent args. Default is ','Boolean values ( as part of a key-value pair ) are convert into the stings 'true' or 'false'.
Validation:
As of 1.0, the ability to optionally check the validity of the Anchor against a schema has been included. Since we don't expect the allowable schema to change during run-time, we use a module configuration to set the schema, like so:
$uriAnchor.configModule({
schema_map : {
page : { profile : true, pdf : true },
_page : {
uname : true,
online : [ 'today','yesterday','earlier' ]
},
slider : { confirm : 'deny' },
_slider : { text : 'goodbye' },
color : { red : true, green : true, blue : true }
}
});
This check occurs only during setting of the Anchor, not during its parsing ( See makeAnchorMap )
The replace_flag
instructs the routine to replace the URI,
discarding browser history
Parses URI anchor and returns as map
none
Expects the document.location browser object
none
Map
none
Parses the browser URI anchor into a map using the same rules used to set the anchor in the method setAnchor ( see above ).
This method creates an additional key type, _s_<indendent_arg>
for each independent argument with dependent arguments.
These keys point to a string representation of the independent argument along with all its dependent arguments.
These values are ignored by setAnchor, but they are useful for routines using setAnchor to check if a part of the anchor has changed.
If the browser URI Anchor looks like this:
#!page=profile:uname,wendy|online,true&slider=confirm:text,hello\
|pretty,false&color=red
Then calling $.uriAnchor.makeAnchorMap(); will return a map that looks like so:
{ page : 'profile',
_page : {
uname : 'wendy',
online : 'true'
},
_s_page : 'profile:uname,wendy|online,true',
slider : 'confirm',
_slider : {
text : 'hello',
pretty : false
},
_s_slider : 'confirm:text,hello|pretty,false',
color : 'red'
};
If you want to help out, like all jQuery plugins this is hosted at GitHub. Any improvements or suggestions are welcome! You can reach me at mike[dot]mikowski[at]gmail[dotcom].
Cheers, Mike
END
FAQs
uriAnchor jQuery plugin - SPA URI routing made simple. Use this plugin to provide sophisticated routing to your SPA. Used in many commercial SPAs and featured in a best-selling book.
The npm package jquery.urianchor receives a total of 10 weekly downloads. As such, jquery.urianchor popularity was classified as not popular.
We found that jquery.urianchor demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.