
Security News
Crates.io Users Targeted by Phishing Emails
The Rust Security Response WG is warning of phishing emails from rustfoundation.dev targeting crates.io users.
ilib-locale
Advanced tools
A BCP-47 locale specifier parser and validator. BCP-47 locale specifiers are also known as IETF locale tags.
npm install ilib-locale
# or
yarn add ilib-locale
Here is how you load ilib-locale:
//ES5
var Locale = require("ilib-locale");
var l = new Locale("ja-JP");
//ES6
import Locale from "ilib-locale";
var l = new Locale("ja-JP");
Here is how you use ilib-locale to parse locale specifiers:
var l = new Locale("zh-Hans-CN");
console.log("Language: " + l.getLanguage()); // outputs "zh"
console.log("Script: " + l.getScript()); // outputs "Hans"
console.log("Region: " + l.getRegion()); // outputs "CN"
Full documentation: Locale class
To get the default locale of the platform, simply make a new Locale instance without parameters.
var locale = new Locale();
console.log("Current locale is " + locale.getSpec()); // output "Current locale is en-US" in the US
This module uses ilib-env
to determine what the current platform is, and looks
in the appropriate place for the locale specifier. For most modern browsers and
recent versions of nodejs, this comes from the Intl
object, which retrieves
the locale from the environment variables or operating system.
If you have the locale parts and would like to construct a locale specifier, pass the parts to the constructor:
var language = "sr";
var script = "Cyrl";
var region = "SR";
var variant = "u-sort-old";
var locale = new Locale(language, region, variant, script);
console.log("Locale spec is " + locale.getSpec()); // output "Locale spec is sr-Cyrl-SR-u-sort-old"
If you have a string and you would like to validate that it forms a valid BCP-47 tag,
you can use the isValid
method to do that:
var l = new Locale("mn-XM");
console.log("Locale is valid: " + l.isValid());
// output "Locale is valid: false" because XM is not a valid region code
In order for a locale spec to be valid, each of its parts needs to conform to the codes in the ISO standard that governs that part:
Copyright © 2021-2025, JEDLSoft
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and limitations under the License.
See CHANGELOG.md
FAQs
A BCP-47/IETF locale specifier parser/validator
We found that ilib-locale demonstrated a healthy version release cadence and project activity because the last version was released less than 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
The Rust Security Response WG is warning of phishing emails from rustfoundation.dev targeting crates.io users.
Product
Socket now lets you customize pull request alert headers, helping security teams share clear guidance right in PRs to speed reviews and reduce back-and-forth.
Product
Socket's Rust support is moving to Beta: all users can scan Cargo projects and generate SBOMs, including Cargo.toml-only crates, with Rust-aware supply chain checks.