A lightweight, customizable masked password input component for Vue3. This component allows you to securely mask password input fields and provides a customizable approach to controlling password visibility.
The InputMaskingPassword component is a password input field that includes masking functionality (hiding characters as the user types) and allows toggling to show or hide the password. It uses the @krozamdev/masked-password
library to apply the masking and supports custom mask characters. The component also handles password input changes by passing the raw (unmasked) value via a callback function.
- Masked Input: Mask the entered password with a configurable mask character.
- Password Toggle: Option to show or hide the password input.
- TypeScript Support: Written in TypeScript for better type safety.
- Easy Integration: Can be easily integrated into any Vue3 form.
- Lightweight: Minimal JavaScript bundle size for better performance.
- Cross-browser Compatibility: Works across modern browsers.
To install the package, use either npm or yarn, etc:
- npm
npm install @krozamdev/vue-masked-password
- yarn
yarn add @krozamdev/vue-masked-password
- pnpm
pnpm add @krozamdev/vue-masked-password
- bun
bun add @krozamdev/vue-masked-password
Here’s an example of how to use the masked password input component in your Vue3 project:
<script setup lang="ts">
import { ref } from 'vue'
import InputMaskingPassword from "@krozamdev/vue-masked-password"
const showPassword = ref(false);
const handleChange = (originalValue: string) => {
console.log("Password changed:", originalValue);
};
const togglePasswordVisibility = () => {
showPassword.value = !showPassword.value;
};
</script>
<template>
<InputMaskingPassword
:onChangeEvent="handleChange"
:showPassword="showPassword"
class="text-primary"
:key="1"
/>
<button @click="togglePasswordVisibility">
{{ showPassword ? 'Hide Password' : 'Show Password' }}
</button>
</template>
Prop | Type | Description |
---|---|---|
onChangeEvent |
(originalValue: string) |
Callback that fires when the password value changes. |
maskCharacter |
string |
(Optional) The character used to mask the password. Defaults to • . |
showPassword |
boolean |
(Optional) Show or hide the password input. Defaults to false . |
...props |
InputHTMLAttributes<HTMLInputElement> |
All other standard HTML input attributes are supported, such as placeholder , class , etc. |
To build the project locally:
- Clone the repository:
git clone https://github.com/krozamdev/vue-masked-password.git cd vue-masked-password
- Install dependencies:
yarn install
- Run the build:
yarn build
This will create the build output in the dist directory, including both CommonJS and ESM formats.
- Fork the repository.
- Create your feature branch (git checkout -b feature/my-feature).
- Commit your changes (git commit -am 'Add new feature').
- Push to the branch (git push origin feature/my-feature).
- Create a new Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.
For support, please email support@krozam.tech.