this.stopScan();
}
},
destroyed:function(){
if(uni.getSystemInfoSync().platform == ‘android’){
/页面退出时一定要卸载监听,否则下次进来时会重复,造成扫一次出2个以上的结果/
this.stopScan();
}
},
methods: {
initScan() {
let _this = this;
main = plus.android.runtimeMainActivity();//获取activity
var IntentFilter = plus.android.importClass(‘android.content.IntentFilter’);
filter = new IntentFilter();
//在PDA设备上直接替换自己的广播动作和广播标签
filter.addAction(“nlscan.action.SCANNER_RESULT”); // 换你的广播动作,
receiver = plus.android.implements(‘io.dcloud.feature.internal.reflect.BroadcastReceiver’,{
onReceive : function(context, intent) {
plus.android.importClass(intent);
let code = intent.getStringExtra(“SCAN_BARCODE1”);// 换你的广播标签
_this.queryCode(code);
}});
},
startScan(){
//注册广播接收器
main.registerReceiver(receiver,filter);
},
stopScan(){
//注销广播接收器
main.unregisterReceiver(receiver);
},
queryCode: function(code){
//防重复
if(_codeQueryTag)return false;
_codeQueryTag = true;
setTimeout(function(){
_codeQueryTag = false;
},150);
var id = code
// console.log(‘id:’, id)
uni.$emit(‘scancodedate’,{code:id})
}
}
}
**2、在登录后第一个响应页面引入组件**
import scan from ‘@/components/scan/scan.vue’
onLoad(){
if(uni.getSystemInfoSync().platform == ‘android’){
console.log(‘安卓’)
uni.$on(‘scancodedate’,function(data){
// _this 这里面的方法用这个 _this.code(data.code)
console.log(‘你想要的code:’, data.code)
})
}
}
**3、在需要使用PDA功能页面直接使用**
onShow(){
if(uni.getSystemInfoSync().platform == ‘android’){
//PDA设备扫描监听
文末
js前端的重头戏,值得花大部分时间学习。
推荐通过书籍学习,《 JavaScript 高级程序设计(第 4 版)》你值得拥有。整本书内容质量都很高,尤其是前十章语言基础部分,建议多读几遍。
另外,大推一个网上教程 现代 JavaScript 教程 ,文章深入浅出,很容易理解,上面的内容几乎都是重点,而且充分发挥了网上教程的时效性和资料链接。
学习资料在精不在多,二者结合,定能构建你的 JavaScript 知识体系。
面试本质也是考试,面试题就起到很好的考纲作用。想要取得优秀的面试成绩,刷面试题是必须的,除非你样样精通。
这是288页的前端面试题