IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3.0--3.isRef、toRefs、toRef、readonly,公共数据配置、网络配置、app.use插件配置、路由配置 -> 正文阅读

[JavaScript知识库]vue3.0--3.isRef、toRefs、toRef、readonly,公共数据配置、网络配置、app.use插件配置、路由配置

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

目录

文章目录

1、isRef,toRefs,toRef

2、readonly

3.公共数据配置

4.网络配置

5、app.use插件配置

6、路由配置



1、isRef,toRefs,toRef

toRef
????????作用:创建一个ref对象,其value指向另一个对象中得某一个属性
????????语法:const name = toRef(data,‘name’)
????????应用:要将响应式对象中得某个属性单独提供给外部使用时

????????拓展:toRefs与toRef功能一致 但可以批量创建多个ref对象 语法:toref(data)

????????为了能在template写的简短,引用toRef处理
????????被toRef包裹的响应式,修改时候直接读取原来响应式reactive代理属性 实时响应变化
????????不使用toRef则响应式的修改就会出现Bug

????????// 使用toRef进行对某个重新赋值的属性添加响应式

const skill = toRef(data,‘skill’)
const age = toRef(data,‘age’)
const name = toRef(data,‘name’)
const salary = toRef(data,‘salary’)
console.log(skill,‘哈哈哈’)
return {data,skill,age,salary,name}

toRefs

????????toRefs为了完善toRef
????????????????1.toRefs可以直接处理多个属性的解构
????????????????2.可以简化代码

????????????????const allProps = toRefs(data)

ref和toRef区别:

????????ref->复制, 修改响应式数据不会影响原始数据

????????ref->数据发生改变, 界面就会自动更新
???????

????????toRef->引用, 修改响应式数据会影响原始数据
????????toRef->数据发生改变, 界面也不会自动更新

isRef、toRef和toRefs的示例应用如下:

2、readonly

????????取得一个对象(反应性或普通)或ref并返回一个只读代理。访问的任何嵌套属性也将是只读的。
????????传入普通对象等返回只读代理。
????????传入普通数值字符串不能变成只读,例如 readonly(‘abc’)

readonly的示例应用如下:

?

注意:

????????在调用父组件方法修改readonly的对象时,没问题。

????????直接在子组件修改父组件对象就会出现警告。

3.公共数据配置

(1)第一种方式

? ? ? ?1、 在vite里面的main.js里面去配置:

const app=createApp(App)
app.config.globalProperties.$hqyj=公共数据

? ? ? ? 2、在app.vue里面去写入:

<script setup>
	import {getCurrentInstance} from "vue"
	let ziduan=getCurrentInstance()
	console.log(ziduan,ziduan.proxy.$hqyj,ziduan.proxy.rank)
</script> 

(2)第二种方式

????????直接在app.vue里面去写入:

<script>
		import {getCurrentInstance} from "vue"
		export default{
				mounted(){
					
				},
				setup(){
					 let {proxy}=getCurrentInstance()
					 console.log(proxy.$hqyj,proxy.rank)
				}
		}
	
</script>

4.网络配置

1.在vite环境里面的vite.config.js里面去配置:

server:{
		proxy: {
		          '/api': { 
		              target: 'http://127.0.0.1:7001', // 代理的目标地址
		              rewrite: (path) => path.replace(/^\/api/, '/'), // 路径重写
		              changeOrigin:true,
		              // secure: true, // target是否https接口
		              // ws: true, // target是否代理websockets               
		          }
		      }
	}

? ? ? ? 2.再去main.js里面去配置:

axios.defaults.baseURL=" http://127.0.0.1:5173/api"
app.config.globalProperties.$axios=axios

? ? ? ? 3.最后再去后端的router.js文件里面和controller里面的home.js里面去写接口。

2.在webpack环境里面的vue.config.js里面去配置:

module.exports={
	lintOnSave:false,
	devServer:{
		port:"10086",
		host:"localhost",
		proxy:{
			"/":{
				target:"http://127.0.0.1:7001",
				changeOrigin:true,
				pathRewrite:{"^/":""}
			}
		}
	}
}

5、app.use插件配置

1.先在main.js文件里面去封装自己要写入的文件:

// 工具的封装
import $axios from "./http/$axios.js"
app.use($axios)
import $hqyj from "./http/$hqyj.js"
app.use($hqyj)

2.在创建相应的文件http,在http里面去创建$axios.js和$hqyj.js后,在去两个文件里面写入自己需要的功能。

$axios.js文件里面:

import axios from "axios"
function $axios(app){
	axios.defaults.baseURL=" http://127.0.0.1:5173/api"
	app.config.globalProperties.$axios=axios
}
export default $axios;

$hqyj.js文件里面:

function $hqyj(app){
	app.config.globalProperties.$hqyj="5000e"
}
export default $hqyj;

6、路由配置

?1.创建
? ? ????????方式一:? ? npm init vite hello-vue3 -- --template vue ? 生成一个模板页面
? ? ????????方式二:???npm init vite taobao ?可以选择集成的插件(路由 仓库 ts 等等)

? ? ? ? ? ?vue3.0的配置方式和vue2.0的配置一样

2.在router.js里面去写:

其他的步骤和vue2.0一样,前提是必须在app.vue页面里面写入

<router-view></router-view>

这样才会显示。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-24 20:47:38  更:2022-09-24 20:50:49 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 15:44:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码