vue常见面试题

VUE常见面试题

vue的双向数据绑定原理

vue数据双向绑定是通过数据劫持结合发布者-订阅者模式的方式来实现
数据劫持的实现方式Object.defineProperty(),该方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性,并返回这个对象,语法Object.defineProperty(obj,prop,descriptor)
当你把一个普通的js对象传入Vue实例作为data选项,Vue将遍历此对象的所有属性,并使用Object.defineProperty()把这些属性全部转换为getter/setter
1.实现一个监听器Observer,用来劫持并监听所有属性,如果有变动的,就通知订阅者
2.实现一个订阅者Watcher,可以收到属性的变化通知并执行相应的函数,从而更新视图
3.实现一个解析器Complie,可以扫描并解析每个节点的相关指令,并根据初始化模板数据以及初始化相应的订阅器

解决跨域问题

jsonp

api/user,js
router.get(’/’, function(req, res ,next) {
let _callback = req.query.callback;
sql.find(User, {}, { _id: 0 }).then(data => {
if (_callback) {
res.type(‘text/javascript’);
res.send(_callback + ‘(’ + JSON.stringify(data) + ‘)’);
} else {
res.json(data)
}
})
})
_ 后端代码 _
调用的地方这样写:

$.ajax({
	url: 'http://localhost:3000/api/user',
	dataType: 'jsonp',
	success: function(data) {
	console.log(data)
	}
})
_前端代码_
cors

app.js里如下设置
var allowCrossDomain = function (req, res ,next) {
res.header(‘Access-Control-Allow-Origin’, ‘*’); //自定义中间件,设置跨域需要的响应头
next();
};
app.use(allowCrossDomain) //运用跨域的中间件

父子组件的传值

父给子传值

父组件在调用子组件的地方
添加一个自定义的属性
属性的值就是要传递给子组件的值

在子组件定义的地方 const Content = {}
添加一个选项 props const Content = { props: }
props的值可以为数组以及对象
如果是数组,元素则为父组件中自定义的属性名、
如果是number/boolean/变量,需要使用到绑定属性
如果是对象有两种写法:
1.验证传递数据的有效性
props: {
test: String,
count: Number,
flag: Boolean,
tip: String
}
2.可以设定属性的默认值
props: {
test: {
type:String,
default: '测试数据了"
}
}
在子组件中就可以通过 {{ test }} 得到父组件传递过来的数据

子给父传值

父组件调用子组件的地方绑定一个自定义的事件,事件不要加()
<my-content @myevent=“getData”/>
在父组件选项methods中实现此事件,默认参数为你将从子组件得到的值
methods: {
getData(val) {
console.log(val)
}
}
在子组件中,可以是生命周期钩子函数,也可以是组件自己的事件触发父组件中的自定义事件
this.$emit('myevent",10000)

兄弟组件之间的传值

const bus = new Vue()
const List = {
template: ‘#list’,
methods: {
add () {
bus.KaTeX parse error: Expected 'EOF', got '}' at position 26: …t-event', 1) }̲ } } const Cou…on(‘count-event’,(val)=> {
console.log(val)
this.num += val
})
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值