当前位置: 首页 > news >正文

门户网站免费奖励自己wordpress导航栏改字体颜色

门户网站免费奖励自己,wordpress导航栏改字体颜色,哪家室内设计好,WordPress首页打开慢1、演示 前言:目前Vue有两种仓库,一种是Vuex,一种是Pinia,懂得都懂,这里就不详细介绍这两者的区别了 2、什么是持久化 仓库里面的数据是需要跨越页面周期的,当页面刷新之后数据还在,在默认情况下…

1、演示

前言:目前Vue有两种仓库,一种是Vuex,一种是Pinia,懂得都懂,这里就不详细介绍这两者的区别了

2、什么是持久化

仓库里面的数据是需要跨越页面周期的,当页面刷新之后数据还在,在默认情况下肯定是不行的,因为仓库里面的数据实际上是存在内存里面的,本质上就是一个对象,对象就在内存里面

如果说需要跨越页面周期的话,就需要把仓库的数据持久化的保存起来,具体的保存位置可以是localStorage、webStorage、sessionStorage、indexD等等,也可以是别的。具体保存在哪里无所谓,反正要保存起来。

3、Vuex的做法

import { createStore } from 'vuex'
import counter from './counter'
import text from './text'
const store = createStore({modules: {counter,text,},plugins: [???],
})

在建立仓库的时候实际上是可以配置插件的,因此可以配置 plugins 属性,让它支持一些插件。插件的本质其实就是一个函数,因此可以在插件中放入一个自己写的函数

这个函数的运行时间在仓库创建之后,并且可以把整个仓库对象(store)传出去

plugin: [persisPlugin]

定义这个函数并接收仓库对象

function persisPlugin(store) {}

存储数据

存储数据一般有两种做法:

1、只要仓库的数据一变,马上就存一次 优点就是实时性会非常高 但是会影响一些效率因为存数据还是比较耗时的

2、在关闭页面或者是刷新页面的时候 之前的页面会被卸载,在页面卸载的时候把数据存起来

  window.addEventListener('beforeunload', () => {localStorage.setItem('VUEX_DATA', JSON.stringify(store.state))})

取出数据

取出数据的方法:

1、在最开始的时候就把它取出来

  try {const state = JSON.parse(localStorage.getItem('VUEX_DATA'))if (state) {// 解析出来了之后就替换掉原来仓库的数据store.replaceState(state)}} catch (error) {console.log('存储的数据有误')}

注意:用 try catch 的原因就是有可能会报错,比如果之前没有存 或者存储的格式被篡改了

完整代码

import { createStore } from 'vuex'
import x1 from './x1'
import x2 from './x2'
const store = createStore({modules: {x1,x2,},plugin: [persisPlugin],
})function persisPlugin(store) {window.addEventListener('beforeunload', () => {localStorage.setItem('VUEX_DATA', JSON.stringify(store.state))})try {const state = JSON.parse(localStorage.getItem('VUEX_DATA'))if (state) {// 解析出来了之后就替换掉原来仓库的数据store.replaceState(state)}} catch (error) {console.log('存储的数据有误')}
}
export default store

4、Pinia的做法 

Pinia也是支持插件的,但是在Vue3中,插件的使用需要同过use方法

import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'
const pinia = createPinia()
const app = createApp(App)
pinia.use(???)
app.use(pinia)
app.mount('#app')

Pinia里面的插件也是一个函数 因此我们定义函数并且使用

function piniaPlugin(context) {}
pinia.use(piniaPlugin)

跟Vuex的区别

1、Pinia接收的不是整个仓库,而是一个context

2、Pinia里面的仓库是分开存储的

3、替换值的时候Vuex用replaceState,Pinia用$pacth

第2点分开存储意思解析

比如这是A仓库

import { defineStore } from 'pinia'
const useStore = defineStore('A',()=>{})

 这是B仓库

import { defineStore } from 'pinia'
const useStore = defineStore('B',()=>{})

3、因此Pinia里面会有多条存储记录

存储数据

Pinia跟Vuex的存储时机是相同的,但是因为有多条记录,因此存储的时候要注意存储的KEY值,这里用仓库ID来区分

window.addEventListener('beforeunload', () => {localStorage.setItem(`Pinia_${store.$id}`, JSON.stringify(store.$state))
})

取出数据

取数据的时候一样,也要根据不同的KEY值来取

  try {const state = JSON.parse(localStorage.getItem(`Pinia_${store.$id}`))if (state) {// 解析出来了之后就替换掉原来仓库的数据store.$pacth(state)}} catch (error) {console.log('存储的数据有误')}

完整代码

import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'
const pinia = createPinia()
const app = createApp(App)
pinia.use(piniaPlugin)
app.use(pinia)
app.mount('#app')
function piniaPlugin(context) {const { store } = contextwindow.addEventListener('beforeunload', () => {localStorage.setItem(`Pinia_${store.$id}`, JSON.stringify(store.$state))})try {const state = JSON.parse(localStorage.getItem(`Pinia_${store.$id}`))if (state) {// 解析出来了之后就替换掉原来仓库的数据store.$pacth(state)}} catch (error) {console.log('存储的数据有误')}
}
// Lorem ipsum dolor sit amet consectetur adipisicing elit. Autem, sed officia eum sit hic dicta voluptatibus tempora reiciendis praesentium dolor!
http://www.yayakq.cn/news/778805/

相关文章:

  • 最好的餐饮设计网站建设电子印章在线制作生成器
  • 北辰做网站句容住房和城乡建设局网站
  • 网站建设怎样核算dede 网站地图模版
  • 深圳网站建设哪个公司好东莞有哪家比较好的网站建设公司
  • 上海平台网站建设企业贵州做网站的公司
  • 没有营业执照网站备案承接各类网站建设
  • 空间设计网站公司北京网站首页排名公司
  • 杭州 企业门户网站建设如何查询域名是否备案
  • 网站建设合同 模板wordpress熊掌号主题
  • 湖北神润建设工程网站dw做旅游网站教程
  • 南宁做网站公司郴州新网0735
  • 百度如何做网站如何建网站详细步骤
  • 什么是网站设计种类河北省建设厅网站网上建设大厅
  • 电子商务 做网站个人工作室网站备案
  • 哪里有做ppt的网站网站用哪个软件做
  • 网站设计的介绍模板建设网站公司哪家技术好
  • 购买空间网站哪个好芗城网站建设公司
  • 深圳网站建设 网站设计wordpress让评论内容
  • 甘肃城乡建设局安全质量网站网站建设需解决问题
  • 望牛墩网站建设唐山做网站企业
  • WordPress批量建站系统一周内重大新闻事件10条
  • 安徽网站制作公司什么是网络营销调研
  • 查排名网站怎样建设影视网站
  • 做夹具需要知道的几个网站网站添加flash
  • 中山外贸网站建设报价北京论坛建站模板
  • asp企业网站源码企业 网站备案
  • 网站显示已备案网址大全有用吗
  • 微信网站开发教程视频教程恩施建站建设
  • 网站的网络设计公司网站建设与维护案例
  • 茶网站开发方案科技术语