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

济南建设企业网站wordpress修改小工具

济南建设企业网站,wordpress修改小工具,wordpress主页打不开,广州专业建网站公司1、动态组件 有的时候&#xff0c;在不同组件之间进行动态切换是非常有用的&#xff0c;比如在一个多标签的界面里&#xff1a; 上述内容可以通过 Vue 的 <component> 元素加一个特殊的 is attribute 来实现&#xff1a; <!-- 组件会在 currentTabComponent 改变时改…

1、动态组件

有的时候,在不同组件之间进行动态切换是非常有用的,比如在一个多标签的界面里:

上述内容可以通过 Vue 的 <component> 元素加一个特殊的 is attribute 来实现:

<!-- 组件会在 `currentTabComponent` 改变时改变 -->
<component :is="item.componentName" v-for="(item,index) in parentNode.childrenNode" :key="index" :parent-node="item" />

在上述示例中,currentTabComponent 可以包括

  • 已注册组件的名字,或一个组件的选项对象

:parent-node="item":将当前遍历到的 item 对象作为数据传递给动态渲染的组件的 parent-node 属性。这样在被渲染的组件内部,就可以通过 props 来接收这个 parent-node 属性的值并使用。

子组件接收 parent-node 属性

以下是一个子组件接收 parent-node 属性的示例:

<template> <div> <!-- 显示接收到的 someData 数据 --> <p>{{ parentNode.someData  }}</p> </div> 
</template> <script> 
export default { props: { parentNode: { type: Object, required: true } } 
}; 
</script> 
在这个子组件中,通过props选项定义了parent-node属性,其类型为对象且是必需的。在模板中,就可以使用 parentNode.someData来显示接收到的数据。

2、inject 语法的具体含义

inject 是 Vue 组件选项中的一部分,用于在当前组件中接收上级组件(不一定是直接父组件)通过 provide 选项提供的数据或方法。inject: ['superParams'] 这种写法是 inject 的数组语法,其含义如下:

  • 数组元素:数组中的每一项都是一个字符串,代表要注入的属性名。在这个例子中,'superParams' 就是要注入的属性名。当前组件期望从上级组件获取名为 superParams 的数据或方法。
  • 数据来源superParams 这个属性需要由上级组件通过 provide 选项提供。provide 选项可以在组件中定义一个对象,该对象的属性和值会被提供给所有下级组件,供它们使用 inject 来注入。

在这个示例中,父组件通过 provide 提供了 superParams 属性,子组件通过 inject 注入了这个属性,从而可以在模板中使用 superParams 的值。

<!-- 父组件 --> 
<template> <div> <child-component></child-component> </div> 
</template> <script> 
import ChildComponent from './ChildComponent.vue';  export default { provide: { superParams: '这是从父组件传递下来的数据' }, components: { ChildComponent } 
}; 
</script> <!-- 子组件 --> 
<template> <div> <p>{{ superParams }}</p> </div> 
</template> <script> 
export default { inject: ['superParams'] 
}; 
</script> <!-- 在对象语法中,可以通过 default 选项为注入的属性设置默认值,当上级组件没有提供该属性时,就会使用默认值--> 
export default { inject: { superParams: { default: '默认值' } } 
}; 

3、Vue.directive 用来创建全局自定义指令

<!DOCTYPE html> 
<html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Vue 2 Custom Directive</title> <!-- 引入 Vue 2 库 --> <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>   
</head> <body> <div id="app"> <!-- 使用自定义指令 v-focus --> <input v-focus type="text"> </div> <script> // 定义全局自定义指令 v-focus Vue.directive('focus',  {// 当被绑定的元素插入到 DOM 中时inserted: function (el) {// 聚焦元素el.focus(); }});// 创建 Vue 2 实例new Vue({el: '#app'});</script> 
</body> </html> 
代码解释
  • Vue.directive('focus', {...}):创建一个名为 v-focus 的全局自定义指令。
  • inserted 钩子函数:当指令绑定的元素插入到 DOM 中时触发,在这个钩子函数里使用 el.focus() 让元素获取焦点。

<!-- 输入验证:对输入框的内容进行实时验证,例如限制输入长度、只允许输入数字等 -->
<template> <input v-numeric-only /> 
</template> <script> 
export default { 
//directives:用来定义组件内部的局部指令。这些指令仅在当前组件中可用。directives: { 'numeric-only': { bind: function (el) { el.addEventListener('input',  function (e) { const value = e.target.value  e.target.value  = value.replace(/[^\d]/g,  '') }) } } } 
} 
</script> 

http://www.dtcms.com/wzjs/784893.html

相关文章:

  • 天猫商务网站建设目的代理公司注册价格
  • 做企业邮箱的网站宏润建设网站
  • 遵义网站制作费用建设门户网站的意见和建议
  • seo网站三种链接商城网站不易优化
  • 天津模板建站哪家好图书页面设计模板
  • 网站开发答辩记录表苏州网站建设哪家效果好
  • 网站开发一定得用html吗苏州建站方法
  • wordpress站内301佛山小学网站建设
  • 怎么开一家网站开发公司科技自立自强
  • 动漫建模需要学什么软件重庆百度seo关键词优化
  • 移动网站建设厂家珠海商城网站建设
  • 安徽建设学校网站旅游网站网页设计报告
  • 广州建网站技术永久免费做网站app
  • 贵州做网站的公司有哪些购买一个网站需要多少钱?
  • seo擦边球网站wordpress 中文企业
  • 做网站用什么语言简单廊坊网站制作公司
  • 开平市网站建设衡粘水佩网站建设
  • 建设网站需要学习什么元宇宙游戏开发
  • 惠州网站制作网站安徽住房和城乡建设部网站首页
  • 桂林两江四湖夜景图片竞价排名和seo的区别
  • 龙华网站建设全包男男做的视频网站
  • 融资网站建设重点网站建设行业地位
  • 服务器重启 iis网站暂停视频网站建设的意义论文
  • 山西省住房与城乡建设厅网站简洁企业网站asp
  • 手工网站和自助建站式网站却别软件科技公司网站模板
  • 阳春做网站如何设计一款app
  • 淘宝网站内搜索引擎优化怎么做网站建设大题
  • 怎样下载模板做网站浙江住房和建设厅网站
  • 怎么拥有自己的网站公司起名字大全免费好听必过的
  • 松原手机网站开发网站内链建设的方法