You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

vue-truncate-read-more

Package Overview
Dependencies
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

vue-truncate-read-more

A Vue.js V3/2 plugin for truncating text with a 'Read More' button to expand the text.

1.1.2
latest
Source
npmnpm
Version published
Maintainers
1
Created
Source

Vue Truncate Readmore

A Vue.js plugin to truncate and expand text content with a customizable read more/less button.

Features

  • Truncate text content to a specified number of characters
  • Display a customizable read more/less button to support multilanguages
  • Activate the plugin based on a minimum character count to prevent truncating short text content
  • Smooth auto scrolling to the content when collapsed and outside of the viewport
  • Supports Vue 2.x and Vue 3.x JS/TS

Table of Contents

  • Installation
  • Usage
  • Contributing
  • License

Stack Blitz Demo

Documentation

Documentation

Installation

npm install vue-truncate-read-more

or

yarn add vue-truncate-read-more

Usage

Global Registration

In your main.js file:

import { createApp } from 'vue';
import App from './App.vue';
import TruncateReadMore from 'vue-truncate-read-more';

const app = createApp(App);
app.use(TruncateReadMore);
app.mount('#app');

Local Registration

In your Vue component:

import TruncateReadMore from 'vue-truncate-read-more';

export default {
  components: {
    TruncateReadMore
  },
};

Template

Assuming data is coming from the server as HTML with markups

In your Vue component's template:

<truncate-read-more
  :truncate-value="200"
  :only-if-more-than-value="275"
>
  <template #html>
    <div
      v-html="data.html"
    />
  </template>
</truncate-read-more>

or in Vue 3.x you can use pascal case:

<TruncateReadMore
  :truncate-value="200"
  :only-if-more-than-value="275"
>
    <template #html>
        <div
        v-html="data.html"
        />
    </template>
</TruncateReadMore>

As a Wrapper

You can also use the plugin as a wrapper around your content or any compoenent that render text:

<truncate-read-more
  :truncate-value="200"
  :only-if-more-than-value="275"
>
    <template #html>
        <div>
        <!-- Your long content -->
        </div>
    </template>
</truncate-read-more>

Props

PropTypeDefaultDescription
truncateValueNumbernullThe number of characters to truncate the text to.
onlyIfMoreThanValueNumbernullActivate the truncate feature only if the text character count is greater than this value.
readMoreButtonTextString'Read more'The text displayed on the read more button.
readLessButtonTextString'Read less'The text displayed on the read less button.

Contributing

Contributions are welcome! To contribute to the project, please follow these steps:

Fork the repository Create a new branch for your feature or bug fix Make your changes and commit them with a clear message Push your changes to your fork Submit a pull request to the main repository Please make sure to follow the code style and conventions used in the project.

If you find a bug or have a feature request, please open an issue on the repository.

License

This project is licensed under the MIT License

Keywords

vue

FAQs

Package last updated on 15 May 2023

Did you know?

Socket

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.

Install

Related posts