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
})
}
}