Detailed explanation of application scenarios of filters in Vue

Detailed explanation of application scenarios of filters in Vue

filter is generally used to filter certain values. For example, if my field is empty, but I want to display “–” on the front end, I can use it.

Recently, I encountered a requirement to set permissions for certain fields to display in other forms, such as displaying the amount that needs to be hidden as "***".

1. Get the amount authority

2. Filter the fields that meet the conditions through filter

3. Return the hidden style

Look at the code:

//For the rest, just look at what I marked. //scope.row gets the current row <template slot-scope="scope">
            <template v-if="item.formType == 'label'">
              <el-button
                v-if="item.link!=undefined"
                type="text" size="small" @click="handleColumnClick(item.link,scope.row)">
                //filter is not generally used for filtering|
                //showLabelValue is not written out //The filter corresponding to one parameter of the method has two parameters //The first one is the value returned by the previous column //The N-1th one is the value you want to pass {{ scope.row | showLabelValue(item) | canViewAmount(canViewAmount,xtType,item) }}
              </el-button>
              <template v-else>
                {{ scope.row | showLabelValue(item) | canViewAmount(canViewAmount,xtType,item) }}
              </template>
            </template>
</template>
export default {
 filters:
 //row is the data returned by scope.rowshowLabelValue(row,item){
 return 'value'
 }
 //value, canView permission, xtType which page, item list data //If showLabelValue returns value, the corresponding canViewAmount parameter value is 'value'
    canViewAmount(value, canView, xtType, item) {
    //If the conditions are met, "***" will be displayed (just display), and the content saved to the database is still the original list if (!canView && xtType == 'salesOrder') {
        if (item.field == 'priceNoTax' || item.field == 'amountNoTax' || item.field == 'price' || item.field == 'amount') {
          return '***'
        }
      }
      if (!canView && xtType == 'project') {
        if (item.field == 'amount' || item.field == 'amountNoTax') {
          return '***'
        }
      }
      return value
    }
  },

Summarize

This article ends here. I hope it can be helpful to you. I also hope you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • How to use filters in VUE
  • Detailed explanation of the problem of Vue filters and directives accessing this
  • The problem of this being undefined when using filters in Vue
  • Solve the problem that vue filters cannot get this object
  • Detailed explanation of Vue's data and event binding and filter filters
  • How to use vue filter
  • Summary of four usages of Vue filter

<<:  The problem of jquery.form.js denying access in IE and the input upload button must be actively clicked

>>:  Detailed explanation of the use of IF(), IFNULL(), NULLIF(), and ISNULL() functions in MySQL

Recommend

MySQL database operations (create, select, delete)

MySQL Create Database After logging into the MySQ...

Mobile browser Viewport parameters (web front-end design)

Mobile browsers place web pages in a virtual "...

SQL merge operation of query results of tables with different columns

To query two different tables, you need to merge ...

Detailed explanation of JSON.parse and JSON.stringify usage

Table of contents JSON.parse JSON.parse Syntax re...

How to install and connect Navicat in MySQL 8.0.20 and what to pay attention to

Things to note 1. First, you need to create a my....

Summary of Commonly Used MySQL Commands in Linux Operating System

Here are some common MySQL commands for you: -- S...

12 Laws of Web Design for Clean Code [Graphic]

Beautiful code is the foundation of a beautiful we...

JS achieves five-star praise case

This article shares the specific code of JS to ac...

Tutorial on installing jdk1.8 on ubuntu14.04

1. Download jdk download address我下載的是jdk-8u221-li...

Details of using vue activated in child components

Page: base: <template> <div class="...