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

表格布局的网站免费网站建设价格费用

表格布局的网站,免费网站建设价格费用,做皮革网站,wordpress怎么放图片不显示不出来1. 基本概念 provide/inject 是 Vue3 中实现跨层级组件通信的方案,类似于 React 的 Context。它允许父组件向其所有子孙组件注入依赖,无论层级有多深。 1.1 基本语法 // 提供方(父组件) const value ref(hello) provide(key, …

1. 基本概念

provide/inject 是 Vue3 中实现跨层级组件通信的方案,类似于 React 的 Context。它允许父组件向其所有子孙组件注入依赖,无论层级有多深。

1.1 基本语法

// 提供方(父组件)
const value = ref('hello')
provide('key', value)// 注入方(子孙组件)
const value = inject('key')

2. 基础用法

2.1 提供静态值

<!-- Parent.vue -->
<script setup>
import { provide } from 'vue'// 提供静态值
provide('theme', 'dark')
provide('language', 'zh-CN')
</script><!-- Child.vue -->
<script setup>
import { inject } from 'vue'// 注入值
const theme = inject('theme')
const language = inject('language')
</script><template><div :class="theme"><p>Current Language: {{ language }}</p></div>
</template>

2.2 提供响应式数据

<!-- Parent.vue -->
<script setup>
import { provide, ref } from 'vue'const count = ref(0)
const updateCount = () => {count.value++
}// 提供响应式数据和更新方法
provide('count', {count,updateCount
})
</script><!-- Child.vue -->
<script setup>
import { inject } from 'vue'const { count, updateCount } = inject('count')
</script><template><div><p>Count: {{ count }}</p><button @click="updateCount">Increment</button></div>
</template>

3. 进阶用法

3.1 使用 Symbol 作为 key

// injection-keys.ts
export const COUNT_KEY = Symbol('count')
export const THEME_KEY = Symbol('theme')
<!-- Parent.vue -->
<script setup lang="ts">
import { provide } from 'vue'
import { COUNT_KEY, THEME_KEY } from './injection-keys'const count = ref(0)
provide(COUNT_KEY, count)
provide(THEME_KEY, 'dark')
</script><!-- Child.vue -->
<script setup lang="ts">
import { inject } from 'vue'
import { COUNT_KEY, THEME_KEY } from './injection-keys'const count = inject(COUNT_KEY)
const theme = inject(THEME_KEY)
</script>

3.2 提供默认值

<script setup>
import { inject } from 'vue'// 使用静态默认值
const theme = inject('theme', 'light')// 使用工厂函数作为默认值
const now = inject('timestamp', () => Date.now())
</script>

3.3 只读数据

<!-- Parent.vue -->
<script setup>
import { provide, ref, readonly } from 'vue'const count = ref(0)
// 提供只读版本,防止子组件修改
provide('count', readonly(count))// 提供更新方法
provide('updateCount', () => {count.value++
})
</script><!-- Child.vue -->
<script setup>
import { inject } from 'vue'const count = inject('count')
const updateCount = inject('updateCount')
</script>

4. 实际应用场景

4.1 主题系统

<!-- ThemeProvider.vue -->
<script setup>
import { provide, ref } from 'vue'const theme = ref('light')
const toggleTheme = () => {theme.value = theme.value === 'light' ? 'dark' : 'light'
}provide('theme', {theme,toggleTheme
})
</script><template><div :class="theme.value"><slot></slot></div>
</template><!-- 使用组件 -->
<script setup>
import { inject } from 'vue'const { theme, toggleTheme } = inject('theme')
</script><template><button @click="toggleTheme">Switch to {{ theme === 'light' ? 'dark' : 'light' }} mode</button>
</template>

4.2 多语言系统

<!-- I18nProvider.vue -->
<script setup>
import { provide, ref } from 'vue'const locale = ref('en')
const messages = {en: {greeting: 'Hello',farewell: 'Goodbye'},zh: {greeting: '你好',farewell: '再见'}
}const t = (key) => messages[locale.value][key]
const setLocale = (lang) => {locale.value = lang
}provide('i18n', {locale,t,setLocale
})
</script><!-- 使用组件 -->
<script setup>
import { inject } from 'vue'const { t, setLocale, locale } = inject('i18n')
</script><template><div><select v-model="locale"><option value="en">English</option><option value="zh">中文</option></select><p>{{ t('greeting') }}</p></div>
</template>

4.3 状态管理

<!-- Store.vue -->
<script setup>
import { provide, reactive } from 'vue'const store = reactive({user: null,todos: [],addTodo(text) {this.todos.push({ id: Date.now(), text, completed: false })},toggleTodo(id) {const todo = this.todos.find(t => t.id === id)if (todo) {todo.completed = !todo.completed}}
})provide('store', store)
</script><!-- TodoList.vue -->
<script setup>
import { inject } from 'vue'const store = inject('store')
</script><template><div><inputv-model="newTodo"@keyup.enter="store.addTodo(newTodo)"><ul><liv-for="todo in store.todos":key="todo.id"@click="store.toggleTodo(todo.id)">{{ todo.text }}</li></ul></div>
</template>

5. TypeScript 支持

5.1 类型定义

// types.ts
export interface ThemeContext {theme: Ref<'light' | 'dark'>toggleTheme: () => void
}export const ThemeSymbol = Symbol('theme')

5.2 带类型的 provide/inject

<script setup lang="ts">
import { provide, inject } from 'vue'
import { ThemeContext, ThemeSymbol } from './types'// 提供方
provide<ThemeContext>(ThemeSymbol, {theme: ref('light'),toggleTheme: () => { /* ... */ }
})// 注入方
const theme = inject<ThemeContext>(ThemeSymbol)
</script>

6. 最佳实践

  1. 使用 Symbol 作为 key

    const MyKey = Symbol('my-key')
    provide(MyKey, value)
    
  2. 提供只读数据

    provide('data', readonly(data))
    
  3. 集中管理 injection key

    // keys.ts
    export const THEME_KEY = Symbol('theme')
    export const I18N_KEY = Symbol('i18n')
    
  4. 使用组合式函数封装

    // useTheme.ts
    export function useTheme() {const theme = inject(THEME_KEY)if (!theme) {throw new Error('useTheme must be used within ThemeProvider')}return theme
    }
    

7. 注意事项

  1. 响应性

    • 确保提供响应式数据时使用 ref 或 reactive
    • 注意数据的可变性和只读性
  2. 默认值

    • 提供合理的默认值
    • 考虑使用工厂函数作为默认值
  3. 类型安全

    • 使用 TypeScript 定义接口
    • 使用 Symbol 作为 key
  4. 性能考虑

    • 避免提供过大的数据结构
    • 合理划分提供的数据范围

通过合理使用 provide/inject,我们可以有效地管理跨组件通信,构建可维护的组件树。但要注意避免过度使用,以免造成数据流向难以追踪的问题。

http://www.yayakq.cn/news/79638/

相关文章:

  • 泰安网络公司推荐搜索引擎优化英文
  • 无锡建站方案域名注册 万网
  • 全球网站流量排名查询西安做网站设计公司
  • 西安市高新区建设局网站会展网站建设
  • 石河子网站设计平面设计很难学吗
  • 网站建设公司顺义发布外链
  • 做带支付平台的网站网站插件开发
  • php做在线直播网站wordpress 首页字数
  • 屏蔽网站推广聚名网官网登录入口
  • 网站301跳转代码wordpress 极简设计
  • 济南建设银行公积金网站自己在线制作logo免费模版
  • 网站设计开发环境建网站的宽带多少钱
  • 如何用ip地址做网站wordpress怎么增加页面
  • 重庆网站网页设计培训机构深圳模板网站建设公
  • 视频网站建设费用明细网站的关键字 设置
  • 成都网站推广营销微信成都住建局官网住建智慧建管
  • aspcms网站地图模板logo设计公司前十名
  • 淘宝运营跟做网站哪种工资高厦门行业网站建设
  • wordpress 搜狐视频合肥seo收费
  • 中国建设银行网站宁波网点企业文化建设方案
  • aspcms手机网站源码珠海关键词优化平台
  • 珠宝类网站建设中国铁建大桥工程局集团有限公司
  • html静态网站开发实验报告网站流量高有什么用
  • 找兼职做网站建设cms开发
  • 快速建立平台网站开发设计建站流程wordpress母公司
  • 加强和改进网站建设建设方案广州市建设厅官方网站
  • 贵安新区网站建设推广百度关键词指数查询工具
  • 福田做网站公司怎么选择专门做养老院的网站
  • 优化一个网站需要多少钱免费下载应用市场
  • 传业做微采商城网站owo表情添加wordpress