您的当前位置:首页>全部文章>文章详情

【Vue】Vue中字符串数组和对象常用方法介绍

CrazyPanda发表于:2024-05-08 23:09:06浏览:281次TAG:

在Vue中,数组和字符串是我们最常处理的数据类型。Vue提供了响应式系统,可以自动跟踪数组和对象的变化,并响应式地更新DOM。在Vue中,您可以像在任何JavaScript应用程序中一样操作这些数据类型。下面时整理的Vue中字符串 数组 以及对象的常用操作方法。

一.数组方法

1.增删改: unshift、push、splice、shift、pop、splice、slice

 1.1.unshift:在数组的头部添加内容

// 数组.unshift("添加的值");        
var arr = ['a','b']
arr.unshift('c');
console.log(arr); //['c', 'a', 'b']
arr.unshift('d');
console.log(arr); //['d', 'c', 'a', 'b']

1.2.push:在数组的尾部添加内容

// arr.push("值");  会在改变原本的数组
var arr = ['a','b']
arr.push('c');
arr.push('d');
console.log(arr);  //['a', 'b', 'c','d']

1.3.splice 在数组的中部添加、删除内容

//3.数组的中间添加/删除元素
//数组.splice(添加或者删除的索引,删除的个数/添加就是0,要添加的值/删除可以不写)
//删除
var arr = ['a','b']
arr.splice(0,1)
console.log(arr); //['b']
//添加
arr.splice(0,0,'c');
console.log(arr); ['c', 'b']

1.4.设置数组的长度

// 直接设置数组的长度 ;(了解)
var arr = [1,2,3,4,5];
arr.length = 3;   // 人为设置 数组长度;
console.log(arr); // [1, 2, 3]

1.5. shift 删除数组的头部元素

// 数组.shift()  删除一个元素
var arr = [1,2,3]
var res = arr.shift();
console.log(arr); // [2, 3]
// 返还值是删除的值;
console.log(res); //1

1.6. pop:尾部删除元素

//数组.pop()
var arr = [1,2,3]
var res = arr.pop();
console.log(arr);// [1, 2]
console.log(res);//3

1.7.splice:增加、删除、修改

  增加

// 增加:ary.splice(n,0,m)从索引n开始删除0项把m或者更多的内容插入到索引n的前面
let arr = [1,2,3,4];
arr.splice(2,0,'a','b')
console.log(arr);//[1, 2, 'a', 'b', 3, 4]

删除

// 数组.splice(删除开始的索引,删除的个数)
// 返还值是删除的元素
var arr = [1,2,3,4,5,6];
var res = arr.splice(1,1);
console.log(res); //[2]
console.log(arr); //[1, 3, 4, 5, 6]

修改

// 修改:arr.splice(n,x,m)
//从索引n开始删除x个,m替换删除的部分把原有内容删除掉,然后用新内容替换掉
let arr = [1,2,3,4,5];
arr.splice(1,2,'x', 'y')
console.log(arr);// [1, 'x', 'y', 4, 5]

1.8.slice:截取数组的元素 ;

 不会改变原本数组,只能获取返还值;

//splice(索引开始,个数) 
var arr = ["a","b","c","d","e"];
//0   1   2   3   4
var res =  arr.slice(1,2);
console.log(res); //['b', 'c']

2.回调函数类: map、filter、reduce、find、findIndex 、some、every、sort

2.1.map:映射

   map是数组高阶函数,它可以遍历数组,然后经过处理进行返回,可以返回新数组,有返回值

//map(item数组每一项本身,index,代表数组下标,arr,代表这整个数组)
//第一个形参是必须写的,第二个第三个可以选填
let arr = [1, 2, 3, 4]
let newArr = arr.map(item => {
    return item * 2
})
let newArr1 = arr.map(item => item * 2)
console.log(newArr1)  //(4) [2, 4, 6, 8]
 
let newArr2 = arr.map(item => {
    return { age: item }
})
console.log(newArr2)   
//(4) [{…}, {…}, {…}, {…}]
//0: {age: 1}
//1: {age: 2}
//3: {age: 3}
//4: {age: 4}

2.2.filter:过滤

将满足条件【return true】的保留,生成一个新的数组

// filter 过滤
/**
 *  将满足条件【return true】的保留,生成一个新的数组
 */
let arr = [1, 2, 3, 4, 5, 6];
let newArr = arr.filter(item => item % 2 === 0)
console.log(newArr)  //(3) [2, 4, 6]
 
let arr2 = [
  {
        id: 1,
        name: '一',
        money: 2000
    },
    {
        id: 2,
        name: '二',
        money: 3000
    },
    {
        id: 3,
        name: '三',
        money: 1000
    },
    {
        id: 4,
        name: '阿黄',
        money: 1000
    },
    {
        id: 5,
        name: '阿汪',
        money: 8000
    }
]
 
let newArr2 = arr2.filter(item => item.money >= 5000)
console.log(newArr2)  //0: {id: 5, name: '阿汪', money: 8000}
 
 
let arr3 = [
    1, 2, 4, -4, undefined, null
]
 
// 按布尔值过滤
let newArr3 = arr3.filter(Boolean)
console.log(newArr3)  //(4) [1, 2, 4, -4]

2.3.reduce:累计

 reduce()方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。

/**
 *  reduce : 一般用来实现 累计
 *  reduce((上一次的值,当前值,索引)=>{},起始值)
 */
 
let arr = [1, 2, 3, 4, 5]
let total = arr.reduce((pre, cur, index) => {
    //  pre     cur     return 
    //   0       1         1
    //   1       2         3
    //   3       3         6
    //   6       4         10
    //   10      5         15
    console.log('pre', pre);
    console.log('cur', cur)
    console.log('index', index)
    return pre + cur
}, 0)
console.log(total)  //15
 
 
let t = arr.reduce((pre, cur) => pre + cur, 0)
 
let todos = [
    {
        id: 1,
        title: '吃饭',
        isDone: true
    },
    {
        id: 2,
        title: '睡觉',
        isDone: true
    },
    {
        id: 3,
        title: '打代码',
        isDone: false
    }                }
]
// 已完成工作的数量
let doneNum = todos.reduce((pre, cur) => pre + cur.isDone, 0)
console.log(doneNum)  //2

2.4.find  finIndex  -查找

    2.4.1 find()方法用于查找数组中符合条件的第一个元素,如果没有符合条件的元素,则返回undefined

    2.4.2 findIndex()方法常用来查找数组中满足条件的第一项元素的下标找到符合条件的一项,返回其下标,找不到 -1

注意:findIndex会给数组中的每一项执行一个函数来判断是否满足表达式,如果满足条件后,剩下的元素则不再执行

// find             找到符合条件的一项 
// findIndex        找到符合条件的一项,返回其下标
// 找到是索引
// 找不到 -1
 
let todos = [
   {
       id: 1,
       title: '吃饭',
       isDone: true
   },
   {
       id: 2,
       title: '睡觉',
        isDone: true
   },
   {
       id: 3,
       title: '打代码',
        isDone: false
   }
]
let todo = todos.find(item => item.id === 1)
// 找到符合条件的一项 
console.log(todo)  //{id: 1, title: '吃饭', isDone: true}
 
let index = todos.findIndex(item => item.id === 10)
//找不到为-1
console.log(index)  //-1
 
let index2 = todos.indexOf({
    id: 3,
    title: '打代码',
    isDone: false
})
//找不到为-1
console.log(index2)  //-1

2.5.some every  -检测

   2.5.1 some:检测数组中是否存在符合指定条件的元素,存在就返回true,不存在就返回false

   2.5.2 every:用于检测数组中某一个值是否都大于或小于或为true或为false。

// 返回一个boolean
// some : 有一个满足即可 
// every: 每一个都要满足
 
let arr = [1, 2, 3, 4]
let res = arr.some(item => item > 30) // 只要有 > 3 的即为真
console.log(res)  //false
 
let res2 = arr.every(item => item > 0)
console.log(res2)  //true

2.6.sort:排序

       方法用于对数组的元素进行排序,并返回数组。默认排序

       顺序是根据字符串UniCode码。因为排序是按照字符串UniCode码的顺序进行排序的,所以首先应该把数组元素都转化成字符串(如有必要),以便进行比较。

// sort : sort改变原来的数组,还会返回得到一个新数组,新数组就是原来的数组
let arr = [1, 23, 45, 3, 4]
let newArr = arr.sort(function (a, b) {
    // return a - b; 升序
    return b - a;
})
console.log(newArr, arr, newArr === arr)
//(5) [45, 23, 4, 3, 1]   (5) [45, 23, 4, 3, 1]   true
 
let names = [
   {
       id: 1,
       name: '一',
       hot: 2000
   },
   {
       id: 2,
       name: '二',
       hot: 4000
   },
   {
       id: 3,
       name: '三',
       hot: 3000
   }, 
   {
       id: 4,
       name: '阿旺',
        hot: 22000
   }
]
 
names.sort(function (a, b) {
    return a.hot - b.hot
})
console.log(names)
//0: {id: 1, name: '一', hot: 2000}
//1: {id: 3, name: '三', hot: 3000}
//2: {id: 2, name: '二', hot: 4000}
//3: {id: 4, name: '阿旺', hot: 22000}

3.其他方法:join、split、reverse、concat、includes [ indexOf ] 、

3.1.join:拼接符

  将数组以拼接符拼接成一个新的字符串

// join(拼接符) 将数组以拼接符拼接成一个新的字符串
let arr = ['a','b','c','d','e']
let str = arr.join('')
console.log(str)  //abcde

3.2.split:拆分符

将字符串以拆分符,拆分为一个新的数组

// split(拆分符) 将字符串以拆分符,拆分为一个新的数组
let arr = '12345'
let newArr = arr.split('')
console.log(newArr)  //(5) ['1', '2', '3', '4', '5']
 
let arr1 = '1-2-3-4-5'
let newArr1 = arr1.split('-')
console.log(newArr1)  //(5) ['1', '2', '3', '4', '5']

3.3.reverse:翻转

  方法用于颠倒数组中元素的顺序。

let str2 = '1-2-3-4-5'
let newArr3 = str2.split('-')
newArr3.reverse()
let newStr = newArr3 
console.log(newStr); //['5', '4', '3', '2', '1']
            
let newStr1 = newArr3.join('-')
console.log(newStr1)  //5-4-3-2-1

3.4.concat:拼接

 方法用于连接两个或多个数组。

let arr1 = ["a", "b", "c"];
let arr2 = ["d", "e", "f"];
let arr3 = arr1.concat(arr2);
console.log(arr3);  //['a', 'b', 'c', 'd', 'e', 'f']

3.5.includes:判断

includes 可以判断一个数组中是否包含某一个元素,并返回true 或者false.与 indexOf相似

// 特殊  includes 返回false、true  
//       indexOf 索引 没找到返回-1
let arr = [1, 2, 3, 4]
let index = arr.indexOf(11)
// if(index !== -1){
// }
console.log(arr.includes(1111))  //false

二.字符串常用方法

1.split、substr、substring、slice、toUpperCase、toLowerCase、 replace、indexOf

1.1.split:根据某个字符 把字符串切割成数组 split(字符)

var str = "a*b*c*d";
var arr = str.split("*");
console.log(arr);

1.2.substr:截取字符串1 : substr  (多)
   字符串.substr(开始截取的索引,截取的数量(不给就到结尾))

var str = "abcdefg";
//    var res =  str.substr(2,2) ;
//  var res = str.substr(2);  //  截取到字符串结尾 ;
// console.log(res);

1.3.substring:字符串.substring(开始截取的索引位置,结束截取的索引位置); 包前不包后

var str = "abcdefg";
var res =  str.substring(2,4);
console.log(res);

1.4.slice:截取字符串

var str = "abcdefg";
var res = str.slice(2,4);
console.log(res);

1.5.toUpperCase:把字符串里的英文变大写

var str = "abcDefG";
var res =  str.toUpperCase();
console.log(res);

1.6.toLowerCase:把字符串里的英文转小写

var str = "abcDefG";
var res =  str.toLowerCase();
console.log(res);
 
// function fn(str){
//     if(str.toLowerCase()==="red"){
//         console.log("红色");
//     }else if(str==="yellow"){
//         console.log("黄色")
//     }else{
//         console.log("其他情况")
//     }
// }
// fn("reD");

1.7.replace:替换字符串 replace("要替换的值","替换的新值");

var  str = "fdafdsaXXXfdafdasXXXddfsa";
str =  str.replace("XXX","***");
str=  str.replace("XXX","***");
console.log(str);


1.8.indexOf:查找某个字符的索引

var str = "abcdefg";
var res =  str.indexOf("h");
console.log(res);

三.对象新增方法

1.is、assign、Object.hasOwn、hasOwnProperty、keys、values、seal

1.1.is:判断对象是否相同

// Object.is();
let obj1 = {
    myname:"张三"
        }
// let obj2 = {
//     myname:"张三"
// }
let obj2 = obj1;
console.log(obj1===obj2);  //true
console.log( Object.is( obj1,obj1));  //true
 
console.log(NaN===NaN);  //false
console.log( Object.is(NaN,NaN));  //true

1.2.assign:合并2个或者多个对象

// 相同键名会覆盖 
// 是一个浅拷贝
let obj1 = {
    name: "带带"
}
let obj2 = {
    age: 20,
}
let obj3 = {
    height: "188cm"
}
 
let res = Object.assign(obj1, obj2, obj3);
console.log(res); //{name: '带带', age: 20, height: '188cm'}
 
obj1.name = "王五";  
console.log(res);   //{name: '王五', age: 20, height: '188cm'}

1.3 hasOwnProperty:ES5判断某个属性是否 是对象的自身属性

let person = {
  name: 'John',
  age: 30,
  job: 'Developer'
};

console.log(person.hasOwnProperty('name')); // Output: true
console.log(person.hasOwnProperty('gender')); // Output: false

1.4.Object.hasOwn:ES6判断某个属性是否 是对象的自身属性

// es6 判断某个属性是否是对象的自身属性
// Object.hasOwn(对象,'对象属性')
// ES5
// obj.hasOwnProperty("对象属性")
 
let obj = {
    myname: "带带",
    age: 20
}
// ES5
console.log(obj.hasOwnProperty("key"));  //flase
console.log(Object.hasOwn(obj, "age"));  //true

1.5.Object.keys();   获取对象的所有键名

// Object.keys();
let obj = {
    myname: "带带",
    age: 20
}
 
let keys = Object.keys(obj);
console.log(keys); //['myname', 'age']

1.6.Object.values();  获取对象的所有键值

// Object.values(); 
// 获取对象的所有键名键值
let obj = {
    myname: "带带",
    age: 20
}
 
let values = Object.values(obj);
console.log(values); // ['带带', 20]

1.7.Object.seal();可以把对象 变成不可配置对象;

// Object.seal();可以把对象 变成不可配置对象(不能添加或删除,可以修改)
let obj = {
    myname: "带带",
    age: 20
}
Object.seal(obj);
obj.myname = "芳芳";
console.log(obj);  //{myname: '芳芳', age: 20}
 
//删除
delete obj.myname;
console.log(obj);   //{myname: '芳芳', age: 20}

四.项目常用案例

1.forEach遍历多层数组数据

classification.forEach(item => {
  console.log(item.text); // 获取每个一级分类的text属性值
  console.log(item.value); // 获取每个一级分类的value属性值
  if (item.children) {
    item.children.forEach(child => {
      console.log(child.text); // 获取每个二级分类的text属性值
      console.log(child.value); // 获取每个二级分类的value属性值
    });
  }
});

2.filter方法 +includes方法来过滤数组

假设你有一个包含多个对象的数组,每个对象都有一个id属性。当有一个不固定的id数组,需要获取不固定id对应的对象数组集合。

let data = [
  { id: 1, name: 'John' },
  { id: 2, name: 'Jane' },
  { id: 3, name: 'Bob' },
  // ...
];
 
let idArray = [1, 3]; // 不固定的id数组
 
let filteredData = data.filter(item => idArray.includes(item.id));

3.使用some方法检查数组中是否存在需要的数据

例:在多条数据中如果含有一条未读消息,列表中将显示未读消息图标;否则,不显示未读消息图标。

// 示例数据
const messages = [
  { id: 1, content: "消息1", is_read: 1 },
  { id: 2, content: "消息2", is_read: 0 },
  { id: 3, content: "消息3", is_read: 1 },
  { id: 4, content: "消息4", is_read: 0 },
];
 
// 检查数组中是否存在未读消息
function hasUnread(messages) {
  return messages.some(message => message.is_read === 0);
}
 
 
//<view class="" v-show="messages && hasUnread(messages)"></view>


猜你喜欢

【Vue】vue2应用与vue3的不同之处
上一篇,我使用了vue2创建了一个应用,这次我使用vue3创建一个应用,看一下两者有什么不同。如下,是我用cue3创建的应用目录发现和vue2应用的目录一模一样,然后我用对比工具对比了两者的文件。1. 文件区别下面是package.json文件的区别,首先vue版本不同,对应的扩展组件也不同。下面是main.js的不同然后是APP.vue的不同2. 全局实例改变2.x 全局 API3.x 实例 API (app)Vue.configapp.configVue.config.productionT
发表于:2024-04-23 浏览:338 TAG:
【Vue】Vue常用框架介绍
现在的应用基本都是前后端分离,在国内,Vue相对来说更受欢迎一些,我们很多后端系统的前端都是Vue来开发的。那么Vue UI框架就显得尤为重要。Vue UI框架提供了一套丰富的用户界面组件及完整的前端UI解决方案,如按钮、表单、导航、布局等,使得开发者可以专注于业务逻辑开发,而不用从零构建这些常用的界面元素,帮助开发者更快速地构建高质量的用户界面。那么,都有哪些开源的UI框架呢?Element UIElement UI是一套为开发者、设计师和产品经理准备的基于Vue 2.0的组件库,提供了丰富的
发表于:2024-04-22 浏览:431 TAG:
【Vue】Vue中如何使用v-for指令循环输出对象
在vue中,v-for是一种指令,在模板中使用它可以对数组或对象进行循环操作。v-for指令用于循环渲染数据,它是vue中非常有用的指令之一。在vue中,使用v-for指令循环输出对象的方式和循环输出数组的方式类似,只需要稍作区别即可。如何使用v-for指令循环输出对象呢?下面我们将分以下几个部分进行讲解。一、v-for指令的基本使用v-for指令的基本语法如下:&lt;div&nbsp;v-for=&quot;(item,index)&nbsp;in&nbsp;items&quot;&gt;{
发表于:2024-04-30 浏览:370 TAG:
【Vue】Antd Pro Vue的使用(三)—— table列表的使用
用了几天ant design pro vue,发现vue2真的不是很好用,各种写法好麻烦。还有研究组件时,一定要看低版本的组件,高版本都是vue3的,并不适用。vue2版本组件位置:https://1x.antdv.com/components/alert-cn/ 作为后台管理端,用到最多的就是table列表,官网给的有预览但是自己上手的时候有事另外一回事了,首先就是接口请求的数据结果,官网并没有介绍接口应该返回什么样的数据结构,导致接口成功请求到数据,但table就是无法正常显示,最终参考de
发表于:2024-04-26 浏览:378 TAG:
【Vue】Vue 前后端分离部署方案
方案 1:Docker创建两个 Docker 容器,一个用于后端,一个用于前端。在后端容器中运行 API 代码。在前端容器中运行 Vue 应用程序并将其打包为静态文件(如 HTML、CSS 和 JS)。方案 2:Nginx 代理安装 Nginx Web 服务器作为反向代理。将后端 API 路由到 Nginx。Nginx 将前端静态文件提供给客户端。方案 3:Node Express使用 Node Express 作为后端框架,它可以将静态文件与 API 路由一起托管。在 Express 应用程序
发表于:2024-05-19 浏览:248 TAG:
【Vue】Antd Pro Vue的使用(十一) —— 富文本编辑器wangeditor的使用(避坑)
我承认,antd pro vue2是免费的,已经是老版本了,有多老呢,自带的wangeditor竟然是V3.1.1版本的,两年前无用wangeditor的时候已经是V5版本了,V3简直是上古的东西,官网都没有找到V3版本的资料。。。。,好在最后还是找到了一份V3版本的资料,要不然又要花时间去用新版本了。wangeditor V3参考资料:https://www.kancloud.cn/wangfupeng/wangeditor3/335782下面是框架组件的配置:问题出现的原因:做商品详情的时候
发表于:2024-05-10 浏览:274 TAG:
【VUE】vue3组件间的通信,父组件调用子组件方法
文章目录一、父组件数据传递N个层级的子组件二、使用v-model指令实现父子组件的双向绑定三、父组件props向子组件传值四、子组件emit向父组件传值五、通过expose和ref来实现父组件调用子组件的方法vue3 provide 与 injectA组件名称 app.vueB组件名称 provideB.vueC组件名称 provideCSetup.vue父组件名称 app.vue子组件名称 v-modelSetup.vue子组件 propsSetup.vue父组件 app.vuevue3 ev
发表于:2024-03-10 浏览:559 TAG:
【Vue】vue框架怎么运行
vue.js是一个用于构建用户界面的javascript框架,其工作原理包括:模板编译:将html模板编译为vdom;响应式系统:检测数据变化并更新vdom;dom更新:有效更新dom,最小化操作次数;自动渲染:监视数据变化并自动重新渲染ui。Vue.js框架的工作原理Vue.js是一个用于构建用户界面(UI)的JavaScript框架。它采用“响应式”系统,当数据发生变化时,框架会自动更新UI,简化了Web开发过程。Vue.js框架的工作流程:1. 模板编译:Vue.js将HTML模板编译为虚
发表于:2024-04-21 浏览:304 TAG:
【Vue】Vue刷新页面的7中方法总结
vue使用中经常会用到刷新当前页面,下面总结一下几种常用的刷新方法,供大家参考。1、 使用 location.reload() 方法进行页面刷新使用&nbsp;location.reload()&nbsp;方法可以简单地实现当前页面的刷新,这个方法会重新加载当前页面,类似于用户点击浏览器的刷新按钮。在 Vue 中,可以将该方法绑定到 Vue 实例上,比如在 Vue 的 methods 中添加如下的方法:methods:&nbsp;{ &nbsp;&nbsp;refresh()&nbsp;{ &amp;n
发表于:2024-05-07 浏览:412 TAG:
【Vue】vue3+node+Element-Ui+spark-md5实现大文件上传、断点续传、秒传、多大文件上传
文章目录目录文章目录前言整体架构流程技术名词解释前端大文件上传断点续传后端大文件上传代码部分js部分的逻辑,按照我们的上面的分析,我们可以写出如下的结构将文件变成二进制,方便后续分片将大文件进行分片创建切片请求将每一个切片 并行/串行 的方式发出后端接口逻辑小结前言在Vue项目中,大图片和多数据Excel等大文件的上传是一个非常常见的需求。然而,由于文件大小较大,上传速度很慢,传输中断等问题也难以避免。因此,为了提高上传效率和成功率,我们需要使用切片上传的方式,实现文件秒传、断点续传、错误重试、
发表于:2023-12-05 浏览:317 TAG: