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

南昌网站建设 南昌做网站公司容易被百度收录的网站

南昌网站建设 南昌做网站公司,容易被百度收录的网站,怎么把网页放到网站上,Wordpress可以卸载吗1.scoped样式冲突 这里提供三个组件,但是只有一个组件加了div样式,结果三个组件都受影响了。 给样式加上scope属性,样式变成局部 给另一个样式添加scope 原理 2.data是一个函数 3.组件通信 子传父$emit 结果: 未点修改前&#xf…

1.scoped样式冲突

这里提供三个组件,但是只有一个组件加了div样式,结果三个组件都受影响了。

给样式加上scope属性,样式变成局部

给另一个样式添加scope

原理

2.data是一个函数

3.组件通信

 

 

 

子传父$emit

结果:

未点修改前:

点击修改后:

4.props详解

类型校验(最常用)

 

简单来说虽然prop的数据是外部的,不能改,但是可以通过通知父组件来该父组件的值,从而达到改数据的目的

5.小黑记事本组件版

添加:

 TodoFooter.vue

<template><!-- 统计和清空 --><footer class="footer"><!-- 统计 --><span class="todo-count">合 计:<strong> {{ list.length }} </strong></span><!-- 清空 --><button class="clear-completed" @click="clear">清空任务</button></footer>
</template><script>
export default {props: {list: {type: Array,},},methods:{clear(){this.$emit('clear')}}
}
</script><style>
</style>

TodoHeader.vue

<template><!-- 输入框 --><header class="header"><h1>小黑记事本</h1><input placeholder="请输入任务" class="new-todo" v-model="todoName" @keyup.enter="handleAdd"/><button class="add" @click="handleAdd">添加任务</button></header>
</template><script>
export default {data(){return {todoName:''}},methods:{handleAdd(){// console.log(this.todoName)this.$emit('add',this.todoName)this.todoName = ''}}
}
</script><style></style>

TodoMain.vue

<template><!-- 列表区域 --><section class="main"><ul class="todo-list"><li class="todo" v-for="(item, index) in list" :key="item.id"><div class="view"><span class="index">{{ index + 1 }}.</span><label>{{ item.name }}</label><button class="destroy" @click="handleDel(item.id)"></button></div></li></ul></section>
</template><script>
export default {props: {list: {type: Array,},},methods: {handleDel(id) {this.$emit('del', id)},},
}
</script><style>
</style>

App.vue

<template><!-- 主体区域 --><section id="app"><TodoHeader @add="handleAdd"></TodoHeader><TodoMain :list="list" @del="handelDel"></TodoMain><TodoFooter :list="list" @clear="clear"></TodoFooter></section>
</template><script>
import TodoHeader from './components/TodoHeader.vue'
import TodoMain from './components/TodoMain.vue'
import TodoFooter from './components/TodoFooter.vue'// 渲染功能:
// 1.提供数据: 提供在公共的父组件 App.vue
// 2.通过父传子,将数据传递给TodoMain
// 3.利用 v-for渲染// 添加功能:
// 1.手机表单数据  v-model
// 2.监听事件(回车+点击都要添加)
// 3.子传父,讲任务名称传递给父组件 App.vue
// 4.进行添加 unshift(自己的数据自己负责)
// 5.清空文本框输入的内容
// 6.对输入的空数据 进行判断// 删除功能
// 1.监听事件(监听删除的点击) 携带id
// 2.子传父,讲删除的id传递给父组件的App.vue
// 3.进行删除filter(自己的数据 自己负责)// 底部合计:父传子  传list 渲染
// 清空功能:子传父  通知父组件 → 父组件进行更新
// 持久化存储:watch深度监视list的变化 -> 往本地存储 ->进入页面优先读取本地数据
export default {data() {return {list: JSON.parse(localStorage.getItem('list')) || [{ id: 1, name: '打篮球' },{ id: 2, name: '看电影' },{ id: 3, name: '逛街' },],}},components: {TodoHeader,TodoMain,TodoFooter,},watch: {list: {deep: true,handler(newVal) {localStorage.setItem('list', JSON.stringify(newVal))},},},methods: {handleAdd(todoName) {// console.log(todoName)this.list.unshift({id: +new Date(),name: todoName,})},handelDel(id) {// console.log(id);this.list = this.list.filter((item) => item.id !== id)},clear() {this.list = []},},
}
</script><style>
</style>

6.非父子通信-事件总线(拓展)

7.非父子通信-provide-inject(拓展)

说白了就是爷爷层里写了共享数据,子孙都可以通过inject来获取该数据。

8.v-model详解

BaseSelect.vue

这里下拉框用的是@change

<template><div><select :value="selectId" @change="selectCity"><option value="101">北京</option><option value="102">上海</option><option value="103">武汉</option><option value="104">广州</option><option value="105">深圳</option></select></div>
</template><script>
export default {props: {selectId: String,},methods: {selectCity(e) {this.$emit('changeCity', e.target.value)},},
}
</script><style>
</style>

App.vue

<template><div class="app"><BaseSelect:selectId="selectId"@changeCity="selectId = $event"></BaseSelect></div>
</template><script>
import BaseSelect from './components/BaseSelect.vue'
export default {data() {return {selectId: '102',}},components: {BaseSelect,},
}
</script><style>
</style>

BaseSelect.vue

<template><div><select :value="value" @change="selectCity"><option value="101">北京</option><option value="102">上海</option><option value="103">武汉</option><option value="104">广州</option><option value="105">深圳</option></select></div>
</template><script>
export default {props: {value: String,},methods: {selectCity(e) {this.$emit('input', e.target.value)},},
}
</script><style>
</style>

App.vue

<template><div class="app"><BaseSelectv-model="selectId"></BaseSelect></div>
</template><script>
import BaseSelect from './components/BaseSelect.vue'
export default {data() {return {selectId: '102',}},components: {BaseSelect,},
}
</script><style>
</style>

9.sync修饰符

BaseDialog.vue

<template><div class="base-dialog-wrap" v-show="isShow"><div class="base-dialog"><div class="title"><h3>温馨提示:</h3><button class="close" @click="closeDialog">x</button></div><div class="content"><p>你确认要退出本系统么?</p></div><div class="footer"><button>确认</button><button>取消</button></div></div></div>
</template><script>
export default {props: {isShow: Boolean,},methods:{closeDialog(){this.$emit('update:isShow',false)}}
}
</script><style scoped>
.base-dialog-wrap {width: 300px;height: 200px;box-shadow: 2px 2px 2px 2px #ccc;position: fixed;left: 50%;top: 50%;transform: translate(-50%, -50%);padding: 0 10px;
}
.base-dialog .title {display: flex;justify-content: space-between;align-items: center;border-bottom: 2px solid #000;
}
.base-dialog .content {margin-top: 38px;
}
.base-dialog .title .close {width: 20px;height: 20px;cursor: pointer;line-height: 10px;
}
.footer {display: flex;justify-content: flex-end;margin-top: 26px;
}
.footer button {width: 80px;height: 40px;
}
.footer button:nth-child(1) {margin-right: 10px;cursor: pointer;
}
</style>

App.vue

<template><div class="app"><button @click="openDialog">退出按钮</button><!-- isShow.sync  => :isShow="isShow" @update:isShow="isShow=$event" --><BaseDialog :isShow.sync="isShow"></BaseDialog></div>
</template><script>
import BaseDialog from './components/BaseDialog.vue'
export default {data() {return {isShow: false,}},methods: {openDialog() {this.isShow = true// console.log(document.querySelectorAll('.box')); },},components: {BaseDialog,},
}
</script><style>
</style>

10.ref和$refs获取dom和组件

BaseChart.vue

<template><div class="base-chart-box" ref="baseChartBox">子组件</div>
</template><script>
import * as echarts from 'echarts'export default {mounted() {// 基于准备好的dom,初始化echarts实例// document.querySelector 会查找项目中所有的元素// $refs只会在当前组件查找盒子// var myChart = echarts.init(document.querySelector('.base-chart-box'))var myChart = echarts.init(this.$refs.baseChartBox)// 绘制图表myChart.setOption({title: {text: 'ECharts 入门示例',},tooltip: {},xAxis: {data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子'],},yAxis: {},series: [{name: '销量',type: 'bar',data: [5, 20, 36, 10, 10, 20],},],})},
}
</script><style scoped>
.base-chart-box {width: 400px;height: 300px;border: 3px solid #000;border-radius: 6px;
}
</style>

App.vue

<template><div class="app"><div class="base-chart-box">这是一个捣乱的盒子</div><BaseChart></BaseChart></div>
</template><script>
import BaseChart from './components/BaseChart.vue'
export default {components:{BaseChart}
}
</script><style>
.base-chart-box {width: 300px;height: 200px;
}
</style>

11.Vue异步更新和$nextTick

异步更新指的是 Vue 对数据变化到 DOM 更新的处理方式不是同步立即执行的,而是采用异步队列的方式进行批量更新。

如果按下图这样写,就满足不了该业务:

如何解决呢?用$nextTick

<template><div class="app"><div v-if="isShowEdit"><input type="text" v-model="editValue" ref="inp" /><button>确认</button></div><div v-else><span>{{ title }}</span><button @click="handleEdit">编辑</button></div></div>
</template><script>
export default {data() {return {title: '大标题',isShowEdit: false,editValue: '',}},methods: {handleEdit(){//1.显示输入框(更新异步dom)this.isShowEdit = true//2.让输入框获取焦点($nextTick等dom更新完,立刻执行准备的函数体)this.nextTick(()=>{console.log(this.$refs.imp)this.$refs.imp.focus()})}}}</script><style>
</style>

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

相关文章:

  • 网站怎么做成小程序上海搜索推广
  • 做网站最好的语言百度统计官网
  • 青岛网站建设和推广青岛关键词排名系统
  • 律师网站深圳网站设计搜狗推广开户
  • 淘宝客导购网站怎么做营销型网站建设团队
  • 织梦商城网站模板网站推广计划
  • 深圳网站设计招聘网北京seo业务员
  • 如何做网站啊南京做网站的公司
  • 大埔县住房和城乡规划建设局网站博客优化网站seo怎么写
  • 重庆免费做网站哈尔滨seo推广优化
  • 饿了么网站怎么做的新媒体营销案例分析
  • 长沙做网站最好的公司有哪些二级子域名ip地址查询
  • 博客式笑话网站织梦源码品牌推广与传播
  • 湛江网站如何制作如何找友情链接
  • 网站开发需要哪些人短视频营销常用平台有
  • 网络营销成功的案例有哪些网站更新seo
  • 北京 网站建设公司百度网盘官网登录首页
  • 用VS做的网站怎么连接数据库站长统计app下载大全
  • 网站代运营费用求职seo服务
  • 学校的网站如何建设方案百度查重工具
  • wordpress不会发送电子邮件网站怎样关键词排名优化
  • 盐城专业做网站的公司哪家好搜索关键词排名提升
  • 网站开发一定要用框架吗seo新人培训班
  • 淘客没有网站难做软件优化
  • 织梦网做企业网站需要授权吗广告免费推广网
  • 潍坊专业网站建设怎么收费企业营销网站制作
  • 商务网站规划与建设课程设计北京网络推广有哪些公司
  • 做旅游网站的目的网站排名优化工具
  • paypal可做网站企业营销案例
  • 做微商哪个网站好网站推广策略