IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> uniapp混合开发总结 -> 正文阅读

[JavaScript知识库]uniapp混合开发总结

修改默认端口号为指定端口号。

1、打开项目中的 manifest.json 文件

2. 点击h5 设置,修改端口

3.重启服务

uniapp 组件通讯

uni.$emit(eventName,OBJECT)

触发全局的自定义事件,附加参数都会传给监听器回调函数。

属性类型描述
eventNameString事件名
OBJECTObject触发事件携带的附加参数

代码示例

	uni.$emit('update',{msg:'页面更新'})

uni.$on(eventName,callback)

监听全局的自定义事件,事件由?uni.$emit?触发,回调函数会接收事件触发函数的传入参数。

属性类型描述
eventNameString事件名
callbackFunction事件的回调函数

代码示例

	uni.$on('update',function(data){
		console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg);
	})

uni.$once(eventName,callback)

监听全局的自定义事件,事件由?uni.$emit?触发,但仅触发一次,在第一次触发之后移除该监听器。

属性类型描述
eventNameString事件名
callbackFunction事件的回调函数

代码示例

	uni.$once('update',function(data){
		console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg);
	})

uni.$off([eventName, callback])

移除全局自定义事件监听器。

属性类型描述
eventNameArray<String>事件名
callbackFunction事件的回调函数

  • 如果uni.$off没有传入参数,则移除App级别的所有事件监听器;
  • 如果只提供了事件名(eventName),则移除该事件名对应的所有监听器;
  • 如果同时提供了事件与回调,则只移除这个事件回调的监听器;
  • 提供的回调必须跟$on的回调为同一个才能移除这个回调的监听器;

注意事项

  • uni.$emit、 uni.$on 、 uni.$once 、uni.$off 触发的事件都是 App 全局级别的,跨任意组件,页面,nvue,vue 等
  • 使用时,注意及时销毁事件监听,比如,页面 onLoad 里边 uni.$on 注册监听,onUnload 里边 uni.$off 移除,或者一次性的事件,直接使用 uni.$once 监听
  • 注意 uni.$on 定义完成后才能接收到 uni.$emit 传递的数据

uniapp--H5与app端交互

native.js

调取安卓或ios原生方法

判断为ios 
function checkIsAppleDevice() {
	var u = navigator.userAgent,
		app = navigator.appVersion;

	var ios = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);

	var iPad = u.indexOf("iPad") > -1;

	var iPhone = u.indexOf("iPhone") > -1 || u.indexOf("Mac") > -1;

	if (ios || iPad || iPhone) {
		return true;
	} else {
		return false;
	}
}

//获取id
function getUserIdId() {
	if (checkIsAppleDevice()) {
		window.webkit.messageHandlers.getUserIdId.postMessage({});
	} else {
		Android.getUserIdId();
	}
}
module.exports = {
    checkIsAppleDevice
    getUserIdId
}

?NativeCallback,js 在app.vue初始化完毕后挂载到window?

window.NativeCallback = NativeCallback;

当调用native.getUserIdId判断ios或者Android app端收到NativeCallback .getUserIdId调用返回id

触发全局的自定义事件 getUserIdId,附加参数都会传给监听器回调函数。

const NativeCallback = {
  getUserIdId: (userIdId) => {
  	uni.$emit('getUserIdId', userIdId)
  },
}
export default NativeCallback;

func,js

监听全局的自定义事件,getUserIdId

 const func = { 
getUserIdId(callback) {
  
  	try {
  		native.getUserIdId()
  		uni.$once('getUserIdId', res => {
  			console.debug('native getUserIdId =>res=' + res)
  			callback(res)
  		})
  	} catch (e) {
  		console.log('getUserIdId err=>' + e.message)
  		callback(false)
  	}
  },
}

export default func;

main,js挂载使用

import Func from './common/func.js';
Vue.prototype.$Func = Func;
    this.$Func.getUserIdId((res) => {
          this.userIdId = res
        })

? 回调函数

? 回调函数就是传递一个参数化的函数,就是将这个函数作为一个参数传到另一个主函数里面,当那一个主函数执行完之后,再执行传进去的作为参数的函数。走这个过程的参数化的函数 就叫做回调函数。换个说法也就是被作为参数传递到另一个函数(主函数)的那个函数就叫做 回调函数。

? ? ? ? 简单来说:回调函数即别人调用了这个函数,即函数作为参数传入另一个函数。

? ? ? ? 1. 自己定义的函数

? ? ? ? 2. 自己没调用

? ? ? ? 3. 函数最终执行了


function test(value){   //这就是回调函数
    console.log(value)
}
function main(test,value){ //test作为一个参数传递进来
    console.log(value)   
    test(value)     // 我是回调函数
}
main(test,'我是回调函数')

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-01 15:07:38  更:2022-06-01 15:09:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 7:54:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码