Vue前端进阶面试题(六)

以下是对您提出问题的详细解答:


Vue 性能优化的方法

  1. 组件划分与按需加载

    • 通过合理划分组件,减少单个组件的复杂度。
    • 使用 Vue Router 的路由懒加载和 import() 进行按需加载。
  2. 使用 v-oncev-if

    • 使用 v-once 对静态内容进行一次性渲染,避免多次计算和更新。
    • 使用 v-if 替代 v-show 处理条件渲染,尤其是对大量元素初始不可见时。
  3. 虚拟滚动

    • 对于长列表或大数据渲染,使用虚拟滚动(如 vue-virtual-scroll-list),只渲染可视区域的元素。
  4. 事件销毁

    • 在组件销毁时,移除事件监听、定时器等,避免内存泄漏。
  5. 避免不必要的响应式

    • 避免响应式数据的深层嵌套;可以使用扁平化的数据结构。
    • 使用 Object.freeze 将常量数据设为不可变。
  6. 使用生产模式

    • 在生产环境下确保使用生产模式 (Vue.config.productionTip = false)。
  7. 开启异步组件更新

    • 确保设置 Vue.config.asynctrue(Vue 3 默认开启)。
  8. 优化依赖追踪

    • 减少 Watcher 和计算属性的依赖,避免不必要的触发。

使用箭头函数定义 Vue 的 watch 属性会有什么结果?

在 Vue 中,使用箭头函数定义 watch 属性会导致**this 的指向问题**。

具体原因:
  • 在箭头函数中,this 会绑定到函数定义时的上下文,而不是运行时的上下文。
  • Vuewatch 函数依赖 this 来指向 Vue 实例。如果使用箭头函数,this 不再指向 Vue 实例,而是指向当前的外部作用域,导致代码运行时错误。
示例:
export default {data() {return { count: 0 };},watch: {count: (newVal, oldVal) => {console.log(this); // 不指向 Vue 实例}}
};

正确写法
使用普通函数表达式:

watch: {count(newVal, oldVal) {console.log(this); // Vue 实例}
}

Redux 和 Vuex 的区别

相同点
  1. 状态管理

    • 都是为了解决跨组件通信和共享状态的问题。
    • 都使用单一状态树。
  2. 核心理念

    • 都遵循 Flux 的单向数据流设计。
    • 都要求状态变更是可预测的,通过专门的函数(mutationsreducers)完成。
不同点
特性ReduxVuex
依赖框架与框架无关,可配合 React、Angular 等使用深度集成 Vue 框架
状态修改方式使用纯函数 Reducers使用 Mutation 必须是同步的
中间件支持有丰富的中间件支持,如 Redux-Thunk、SagaVuex 内置支持 Actions 处理异步逻辑
调试工具强大的 Redux DevToolsVue Devtools 同样支持 Vuex
写法复杂度配置较复杂,需引入较多概念配置较简单,与 Vue 语法深度融合
共同设计思想
  • 单向数据流。
  • 状态的集中化管理。
  • 状态不可变性(通过专门的修改函数实现状态修改)。
  • 强调可预测的状态变更和调试友好性。

如何在 Vue 项目中引入 SCSS?引入后如何使用?

步骤 1:安装 SCSS 依赖
npm install sass sass-loader --save-dev
步骤 2:配置 SCSS

通常在 Vue CLI 项目中,无需额外配置即可直接使用 SCSS。如果需要配置全局 SCSS 变量,可修改 vue.config.js

module.exports = {css: {loaderOptions: {sass: {additionalData: `@import "@/styles/global.scss";`}}}
};
步骤 3:在组件中使用 SCSS
<template><div class="example">Hello SCSS</div>
</template><style lang="scss">
.example {color: $main-color;
}
</style>

Vue 3 使用的 DIFF 算法相比 Vue 2 的双端比对有什么优点?

Vue 3 使用了长按递归快速路径优化的 DIFF 算法,相比 Vue 2 的双端比对,其性能更高,特别是在大规模节点更新时。

优点
  1. 性能优化

    • Vue 3 的 DIFF 算法基于动态规划和最短递增子序列(LIS)的思想,减少了节点的移动次数。
    • 对于大列表的部分更新,性能显著提升。
  2. 更细粒度的优化路径

    • 优化了子树相同前缀和后缀的比较(通过头尾指针)。
    • 对完全相同的子树跳过递归更新。
  3. 代码简洁性

    • 新的 DIFF 算法在代码实现上更加模块化和清晰。

Vue 自定义指令的生命周期钩子函数有哪些?

Vue 自定义指令的生命周期钩子函数如下(Vue 3 中):

  1. created

    • 指令绑定到元素上时调用,但此时还没有插入 DOM。
  2. beforeMount

    • 元素即将插入到 DOM 中时调用。
  3. mounted

    • 元素已经插入到 DOM 中时调用,可以操作真实 DOM。
  4. beforeUpdate

    • 在包含指令的组件更新之前调用。
  5. updated

    • 在包含指令的组件更新之后调用。
  6. beforeUnmount

    • 元素即将被移出 DOM 时调用。
  7. unmounted

    • 元素被移出 DOM 后调用。
示例:
app.directive('focus', {mounted(el) {el.focus();},updated(el) {console.log('Updated!');}
});

使用 Vue 开发一个任务列表应用的设计实现

在开发一个任务列表应用时,使用 Vue.js 可以通过以下步骤进行:

  1. 项目初始化:使用 Vite 或其他现代前端构建工具(如 Webpack)初始化项目,快速生成项目的基础结构。

  2. 梳理项目结构:创建一个清晰的项目结构,通常包括 src 目录(存放源代码)和 public 目录(存放公共资源)等。

  3. 封装组件

    • 封装 todo-list 组件:用于渲染整个任务列表,包含子组件(todo-item)的列表,并提供添加、删除任务等功能。
    • 封装 todo-input 组件:负责接收用户的输入并添加新任务到列表中。可能需要绑定键盘事件监听器,以便在用户按下回车键时提交任务。
    • 封装 todo-button 组件:可以是一个功能性的按钮,例如用于删除任务或标记任务完成的按钮。
  4. 实现功能:利用 Vue 的数据绑定、事件处理、计算属性等特性,实现添加、删除、编辑任务等功能。

Vue 打包后最终生成的文件

Vue 打包后通常会生成一组静态文件,主要包括:

  1. HTML 文件:主 HTML 文件(如 index.html),是应用的入口文件。它包含了基本的 HTML 结构,并通过 script 标签引入打包后的 JavaScript 文件。如果是多页面应用,可能会生成多个 HTML 文件。

  2. JavaScript 文件

    • app.js/main.js:应用的主要 JavaScript 文件,包含了应用的核心逻辑和 Vue 组件。
    • vendor.js:包含了项目中使用的第三方库和依赖项,如 Vue 框架本身、Vue Router、Vuex 等。
    • chunk 文件:如果项目使用了代码拆分(Code Splitting),可能会生成多个 chunk 文件,这些文件包含了应用的不同部分,以便按需加载。
  3. CSS 文件:用于定义应用的样式,通常包括 app.css(应用的主要样式文件)和 vendor.css(如果项目使用了外部 CSS 库,这些库的样式可能会被打包到这个文件中)。

  4. 静态资源文件:包括应用中使用的所有静态文件,如图片、字体、图标等。这些文件通常会被打包并放置在一个专门的目录中(如 /assets 或 /static),以便在应用中引用。

Element UI 是否支持移动端及注意事项

Element UI 最初是为 Web 应用程序设计的,但也可以用于移动端开发。不过,在移动设备上使用 Element UI 可能会遇到一些问题,如字体顶部被截掉、下拉框在 iOS 上要点两次才选中、点击出现蓝色半透明背景框等。为了确保良好的用户体验,需要对 Element UI 进行一些调整和优化,例如对组件进行缩放、限制页眉页脚高度、禁用不必要的 tooltip 等。

Vuex 的 state、getter、mutation、action、module 的作用

  1. state:用于存储全局状态,是 Vuex 中的核心属性。
  2. getter:用于计算和检索状态衍生数据,可封装数据、提供缓存和提高可测试性。
  3. mutation:用于更改 state 中的状态,是一个同步的操作。所有的状态变更都必须通过 mutation 来完成,以保证状态变化可追踪。
  4. action:用于执行异步操作,可以包含任意异步操作,并在完成后提交对应的 mutation 来变更状态。
  5. module:支持模块化管理,允许将 store 分割成多个模块,每个模块拥有自己的 state、getters、mutations 和 actions。

扩展现有 Vue 组件的方法

如果想扩展某个现有的 Vue 组件,可以通过以下方式:

  1. 封装新组件:创建一个新的 Vue 组件,将需要扩展的功能封装在这个新组件中。
  2. 组合使用:在现有的组件中引入新创建的组件,并通过插槽(slot)或属性(props)将数据和功能传递给新组件。
  3. 继承现有组件(不推荐):虽然 Vue 不支持类继承,但可以通过混入(mixins)或高阶组件(HOC)等方式实现类似继承的效果。不过,这种方式可能会增加代码的复杂性和维护成本,因此通常不推荐使用。

在 Vue 中定义全局的方法

在 Vue 中定义全局的方法可以通过以下方式:

  1. Vue.prototype:可以在 Vue 的原型对象上添加方法,这样所有 Vue 实例都可以访问这些方法。例如:
Vue.prototype.$myMethod = function (methodOptions) {// 方法的实现
}

在组件中,可以通过 this.$myMethod() 来调用这个方法。

  1. 全局混入:使用 Vue.mixin() 方法将混入对象应用到所有的 Vue 实例中。混入对象可以包含选项(如 data、methods、created 等),这些选项将被合并到所有的 Vue 实例中。

Vue 监听数组或对象变化的情况

Vue 可以通过 getter 和 setter 来监听数组或对象的变化。当数组或对象的属性被修改时,Vue 会触发相应的更新。然而,对于以下情况,Vue 可能无法监听到变化:

  1. 数组的长度变化:Vue 不能监听数组长度的变化。如果需要监听数组长度的变化,可以使用 splice()push()pop() 等方法,这些方法会触发 Vue 的响应式系统。
  2. 对象属性的添加或删除:Vue 不能监听对象属性的添加或删除。如果需要监听这些变化,可以使用 Vue.set() 或 Vue.delete() 方法,这些方法会确保响应式系统的更新。

对于无法监听的情况,可以使用 Vue 提供的 Vue.set()Vue.delete() 方法来确保响应式系统的更新。此外,还可以使用计算属性或观察者(watcher)来手动监听和响应数组或对象的变化。
以下是您提到的问题的详细解答:


什么是 Vue 的 Proxy? 它有什么作用?

Vue 的 Proxy

在 Vue 3 中,Proxy 替代了 Vue 2 中的 Object.defineProperty 来实现响应式系统。

作用
  1. 响应式代理

    • Proxy 直接代理对象的所有操作(包括属性读取、设置、删除等),实现数据的响应式。
    • 能处理嵌套对象,无需逐层递归劫持。
  2. 更强的能力

    • 支持对新增属性的监听(Vue 2 无法监听动态添加的属性)。
    • 支持对数组的监听(如直接修改数组索引或长度)。
  3. 性能优化

    • 在 Vue 2 中,深度嵌套对象会导致大量递归操作,而 Proxy 是懒代理,只有访问到某层时才代理该层。
示例
const reactiveHandler = {get(target, key) {console.log('Getting:', key);return target[key];},set(target, key, value) {console.log('Setting:', key, value);target[key] = value;return true;}
};const state = new Proxy({ count: 0 }, reactiveHandler);
state.count; // 输出 "Getting: count"
state.count = 1; // 输出 "Setting: count 1"

Vue 中 prop 验证的 type 类型有哪几种?

Vue 中的 prop 验证可以使用以下类型:

  1. 基础类型

    • String
    • Number
    • Boolean
    • Array
    • Object
    • Function
    • Symbol
  2. 多类型

    • 可以传递一个数组来允许多个类型。
    • 示例:[String, Number]
  3. 自定义验证

    • 使用 validator 函数进行更复杂的校验。
    • 示例:
      props: {age: {type: Number,validator(value) {return value > 0 && value < 120;}}
      }
      

什么是 Vue 的 extend 构造器? 它的作用是什么?

Vue 的 extend 构造器

Vue.extend 是 Vue 2 中提供的 API,用于创建一个基于 Vue 的子类构造器,通常用于动态生成组件。

作用
  1. 动态创建组件
    • 用于需要大量动态创建组件实例的场景。
  2. 继承功能
    • 可以通过扩展 Vue 基类生成具有特定功能的子类。
示例
const MyComponent = Vue.extend({template: '<div>Hello, {{ name }}</div>',data() {return { name: 'Vue' };}
});const instance = new MyComponent();
instance.$mount('#app'); // 挂载到 DOM

如何避免 Element UI 组件的频繁重新渲染,提升应用的性能?

优化方法
  1. 合理使用 key

    • 确保每个动态渲染的组件有唯一的 key,以减少不必要的重新渲染。
  2. 减少依赖数据更新

    • 避免使用整个对象作为绑定数据,尽量传递精简的属性。
  3. 避免不必要的响应式数据

    • 对于不需要响应式的数据,使用非响应式对象或 Object.freeze
  4. 懒加载组件

    • 使用 keep-alive 包裹组件以缓存不需要频繁更新的组件。
  5. 虚拟滚动

    • 对于大列表,使用 element-uivirtual-list 或其他虚拟滚动库。

Vue Router 的懒加载如何实现?

实现方式
  1. 动态引入组件

    • 使用 import() 实现懒加载。
    const routes = [{path: '/about',component: () => import('./components/About.vue') // 懒加载}
    ];
    
  2. 结合 Webpack 的 /* webpackChunkName */

    • 给懒加载的模块命名,方便调试。
    const routes = [{path: '/about',component: () => import(/* webpackChunkName: "about" */ './components/About.vue')}
    ];
    

Vuex 有哪几种属性? 分别有什么作用?

Vuex 主要有以下几种属性:

  1. State

    • 存储全局共享状态。
    • 示例:
      const store = new Vuex.Store({state: { count: 0 }
      });
      
  2. Getters

    • 类似于计算属性,用于对 state 派生出新数据。
    • 示例:
      getters: {doubleCount: state => state.count * 2
      }
      
  3. Mutations

    • 唯一修改 state 的方式,必须是同步的。
    • 示例:
      mutations: {increment(state) {state.count++;}
      }
      
  4. Actions

    • 用于处理异步操作或复杂逻辑。
    • 示例:
      actions: {asyncIncrement({ commit }) {setTimeout(() => {commit('increment');}, 1000);}
      }
      
  5. Modules

    • 用于模块化管理状态。
    • 示例:
      const store = new Vuex.Store({modules: {cart: {state: { items: [] }}}
      });
      

Vuex 的 action 和 mutation 之间有什么区别?

特性MutationAction
触发方式通过 commit 触发通过 dispatch 触发
执行逻辑只能包含同步逻辑可以包含异步逻辑
修改状态直接修改状态通过调用 mutation 修改状态

Vuex 和单纯的全局对象有什么区别?

  1. 响应式

    • Vuex 的状态是响应式的,能够实时更新到 Vue 组件。
    • 全局对象无法自动跟踪数据变化。
  2. 模块化

    • Vuex 支持状态、操作的模块化管理。
    • 全局对象容易导致代码混乱。
  3. 调试工具

    • Vuex 提供调试工具(如 Vue Devtools),方便追踪状态变化。

Element UI 的穿梭组件在数据量大时变卡,怎么优化?

优化方法
  1. 虚拟列表

    • 使用虚拟列表只渲染可见区域。
  2. 延迟加载

    • 在需要时才加载数据。
  3. 异步操作

    • 对数据操作分批进行,避免主线程阻塞。
  4. 减少依赖响应式

    • 大数据操作中避免对整个列表使用响应式对象。

Element UI 如何支持国际化? 在多语言项目中如何切换语言?

支持国际化
  1. 安装依赖:

    npm install element-plus --save
    npm install @element-plus/locale --save
    
  2. 配置国际化:

    import { createApp } from 'vue';
    import ElementPlus from 'element-plus';
    import zhCn from 'element-plus/es/locale/lang/zh-cn';
    import en from 'element-plus/es/locale/lang/en';const app = createApp(App);
    app.use(ElementPlus, { locale: zhCn }); // 默认中文
    
切换语言

动态切换语言时,可以更新 locale 属性:

import { useLocale } from 'element-plus';const { locale } = useLocale();
locale.value = en; // 切换为英文

在 Vue 开发过程中需要同时与多个后端人员联调接口时,你会怎么做?

  1. 使用接口代理

    • 配置 Vue CLI 的 devServer.proxy,避免跨域问题。
  2. 接口 Mock

    • 使用 Mock 数据模拟接口,减少依赖后端开发的进度。
  3. 模块化接口管理

    • 每个后端开发者负责的接口分模块管理。

Vuex 使用 actions 时不支持多参数传递怎么办?

问题分析

Vuex 的 actions 默认只接收两个参数:

  1. context:上下文对象,包含 commitdispatch 等方法。
  2. payload:单个参数,用于传递数据。

因此,actions 的调用实际上不支持直接传递多个独立的参数。


解决方法
  1. 封装为对象
    将多个参数封装为一个对象,方便在 actions 中解构处理。

    示例

    actions: {exampleAction(context, payload) {const { param1, param2 } = payload;console.log(param1, param2);}
    }store.dispatch('exampleAction', { param1: 'value1', param2: 'value2' });
    
  2. 使用数组封装
    如果顺序明确,可以将多个参数封装成数组传递,但解读时稍显不直观。

    示例

    actions: {exampleAction(context, [param1, param2]) {console.log(param1, param2);}
    }store.dispatch('exampleAction', ['value1', 'value2']);
    
  3. 直接访问外部变量
    如果参数较多且复杂,可以通过闭包或模块的外部变量访问,但不推荐,可能导致数据污染和维护困难。


v-if 和 v-for 在 Vue 中的优先级是什么?

优先级规则
  1. v-for 优先级高于 v-if
    • Vue 在渲染时会先解析 v-for,即先对列表进行遍历。
    • 然后在遍历过程中,再对每个元素判断 v-if 的条件。
潜在问题
  1. 性能问题

    • 如果列表数据量较大,而大部分元素需要被过滤掉,那么仍会先遍历整个列表,造成性能浪费。
  2. 逻辑复杂性

    • v-ifv-for 结合会导致代码逻辑难以维护。

优化策略
  1. 提前过滤数据

    • 在渲染之前通过计算属性或方法过滤列表,只保留需要渲染的项。

    示例

    computed: {filteredList() {return this.list.filter(item => item.visible); // 提前过滤}
    }
    

    模板

    <div v-for="item in filteredList" :key="item.id">{{ item.name }}
    </div>
    
  2. 使用 template 包裹

    • 如果必须结合 v-ifv-for,使用 template 包裹,确保逻辑清晰。
    <template v-for="item in list" :key="item.id"><div v-if="item.visible">{{ item.name }}</div>
    </template>
    
  3. 减少数据量

    • 对于大数据量的场景,结合分页或虚拟滚动(如 vue-virtual-scroller)避免一次性加载过多元素。

总结
  • 优先使用提前过滤数据,以避免无意义的遍历。
  • 在特殊需求下,可以结合 template 明确逻辑,保持代码清晰。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/60975.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux环境变量(添加环境变量、修改系统环境变量、内建命令和非内建命令)

Linux环境变量&#xff08;添加环境变量、修改系统环境变量、内建命令和非内建命令&#xff09; 1. 环境变量的介绍 环境变量&#xff08;environment variables&#xff09;一般是指在操作系统中用来指定操作系统运行环境的一些参数。环境变量是在操作系统中一个具有特定名字…

排序算法之插入排序篇

插入排序 思路&#xff1a; 就是将没有排序的元素逐步地插入到已经排好序的元素后面&#xff0c;保持元素的有序 视频的实现过程如下&#xff1a; 插入排序全过程 代码实现过程如下&#xff1a; public static void Insertion(int[] arr) { for (int i 1; i < arr.length…

AVL、B树和B+树

AVL树定义 AVL树&#xff08;Adelson-Velsky 和 Landis 树&#xff09;是一种自平衡的二叉搜索树&#xff08;Binary Search Tree, BST&#xff09;&#xff0c;由苏联数学家Georgy Adelson-Velsky和Evgenii Landis在1962年提出。AVL树通过在每个节点上维护一个平衡因子&#…

Unity ShaderLab 实现3D物体描边

实现思路&#xff1a; 给物体添加第二个材质球&#xff0c;在shader的顶点着色器中使顶点的位置变大&#xff0c;然后在片元着色器中输出描边颜色。 shader Graph实现如下&#xff1a; ShaderLab实现如下&#xff1a; Shader "Custom/Outline" {Properties{[HDR]_…

【C++第三方库】Muduo库结合ProtoBuf库搭建服务端和客户端的过程和源码

每日激励&#xff1a;“不设限和自我肯定的心态&#xff1a;I can do all things。 — Stephen Curry” 绪论​&#xff1a; 本章我将结合之前的这俩个第三方库快速上手protobuf序列化和反序列化框架和muduo网络&#xff0c;来去实现muduo库在protocol协议搭建服务端和客户端。…

Jenkins的使用

文章目录 一、Jenkins是什么\有什么用\与GitLab的对比二、Jenkins的安装与配置Jenkins的安装方式在Linux上安装Jenkins&#xff1a;在Windows上安装Jenkins&#xff1a;配置Jenkins&#xff1a; &#xff08;可选&#xff09;配置启动用户为root&#xff08;一定要是root吗??…

Qml-TabBar类使用

Qml-TabBar类使用 TabBar的概述 TabBar继承于Container 由TabButton进行填充&#xff0c;可以与提供currentIndex属性的任何容器或布局控件一起使用&#xff0c;如StackLayout 或 SwipeView&#xff1b;contentHeight : real:TabBar的内容高度&#xff0c;用于计算标签栏的隐…

Cyberchef 辅助网络安全运营-数据格式转换

在网络安全的世界中&#xff0c;经常会遇到各种格式的数据&#xff0c;比如二进制&#xff0c;比如说16进制&#xff0c;URL编码&#xff0c;HTML编码&#xff0c;Unicode编码&#xff0c;Base格式的编码。网络安全运营一个明确的目标就是把这些不同的数据格式换成为可读的字符…

C语言——指针初阶(一)

目录 一.什么是指针&#xff1f;&#xff1f;&#xff1f; 指针是什么&#xff1f; 指针变量&#xff1a; 总结&#xff1a; 总结&#xff1a; 二.指针和指针类型 指针-整数&#xff1a; 总结&#xff1a; 指针的解引用 总结&#xff1a; 三.野指针 如何规避野指针 往期…

Tcon技术和Tconless技术介绍

文章目录 TCON技术&#xff08;传统时序控制器&#xff09;定义&#xff1a;主要功能&#xff1a;优点&#xff1a;缺点&#xff1a; TCONless技术&#xff08;无独立时序控制器&#xff09;定义&#xff1a;工作原理&#xff1a;优点&#xff1a;缺点&#xff1a; TCON与TCONl…

World of Warcraft /script SetRaidTarget(“target“, n, ““) n=8,7,6,5,4,3,2,1,0

魔兽世界执行当前目标标记方法 /script SetRaidTarget("target", n, "") n8,7,6,5,4,3,2,1,0 解析这个lua脚本 D:\Battle.net\World of Warcraft\_classic_\Interface\AddOns\wMarker wMarker.lua /script SetRaidTarget("target", 8, &quo…

学习笔记035——MySQL索引

数据库索引 索引是为了提高数据的查询速度&#xff0c;相当于给数据进行编号&#xff0c;在查找数据的时候就可以通过编号快速找到对应的数据。 索引内部数据结构&#xff1a;B Tree 主键自带索引。 如&#xff1a; insert into user (id, name) values (1,f); insert int…

在Unity中实现物体动画的完整流程

在Unity中&#xff0c;动画是游戏开发中不可或缺的一部分。无论是2D还是3D游戏&#xff0c;动画都能为游戏增添生动的视觉效果。本文将详细介绍如何在Unity中为物体添加动画&#xff0c;包括资源的准备、播放组件的添加、动画控制器的创建以及动画片段的制作与调度。 1. 准备动…

Python数据分析实例五、US 大选捐款数据分析

美国联邦选举委员会 (FEC) 公布了对政治竞选活动的贡献数据。这包括投稿人姓名、职业和雇主、地址和投款金额。2012 年美国总统大选的贡献数据以单个 150 MB 的 CSV 文件P00000001-ALL.csv形式提供,该文件可以通过以下pandas.read_csv加载: import pandas as pdfec = pd.r…

vue3项目搭建-3-Pinia的使用

Pinia 是集中状态管理工具 基本用法 Pinia 是 Vue 的专属的最新状态管理库&#xff0c;是 Vuex 状态管理工具的替代品 官方文档&#xff1a;pinia官方文档 找到开始目录&#xff0c;根据文档安装和入门 pinia&#xff0c;启用一个新的终端&#xff0c;输入指令 npm install…

SAP开发语言ABAP开发入门

1. 了解ABAP开发环境和基础知识 - ABAP简介 - ABAP&#xff08;Advanced Business Application Programming&#xff09;是SAP系统中的编程语言&#xff0c;主要用于开发企业级的业务应用程序&#xff0c;如财务、物流、人力资源等模块的定制开发。 - 开发环境搭建 - 首先需…

修改bag的frame_id的工具srv_tools

在使用数据集导航或者建图时&#xff0c;bag中的点云或者其他话题的frame_id没有和需要的对应 1.创建工作空间 2.cd xxxx/src 3.git clone https://github.com/srv/srv_tools.git cd .. catkin_make source ./devel/setup.bash rosrun bag_tools change_frame_id.py -t /要改…

IDEA2023版本配置项目全局编码

IDEA默认的项目编码是UTF-8&#xff0c;有时候拿到别人的代码使用的编码是GBK&#xff0c;虽然可以在idea右下角进行修改&#xff0c;但是一个一个的修改太慢了。所以需要去进行该项目的编码全局配置。接下来直接讲步骤&#xff0c;以IDEA2023版本为例。 第一步 File>Sett…

大数据学习18之Spark-SQL

1.概述 1.1.简介 Spark SQL 是 Apache Spark 用于处理结构化数据的模块。 1.2.历史 1.2.1.Shark Hadoop诞生初期&#xff0c;Hive是唯一在Hadoop上运行的SQL-on-Hadoop工具&#xff0c;MR的中间计算过程产生了大量的磁盘落地操作&#xff0c;消耗了大量的I/O&#xff0c;降低…

【Android】Service使用方法:本地服务 / 可通信服务 / 前台服务 / 远程服务(AIDL)

1 本地Service 这是最普通、最常用的后台服务Service。 1.1 使用步骤 步骤1&#xff1a;新建子类继承Service类&#xff1a;需重写父类的onCreate()、onStartCommand()、onDestroy()和onBind()方法步骤2&#xff1a;构建用于启动Service的Intent对象步骤3&#xff1a;调用st…