网站首页 > 技术文章 正文
素材编辑 | 宋大狮
排版运营 | 小唐狮
ONE 问题描述
因为许久没有接触小程序项目,今天在做小程序项目时,为了节省时间,将要修改的页面组件直接拿出来封装成了公共组件,同时也没多想就直接使用了。于是就出现了页面数据不能加载的问题,在一番打印查找之后,发现是组件中onLoad方法一直没有执行,导致内部的方法没有调用,表格里的数据没有拿到。
TWO 解决过程
尝试一:
思路:onLoad方法没有执行,考虑是否是页面未重新加载导致。
实现:使用onShow方法,把onLoad方法中的函数搬到onLoad方法中调用。
结果:失败,onShow方法依然没有执行。
尝试二:
思路:既然不是声明周期的问题,考虑是否有其它Api可用。
实现:在网上一番搜索,并查阅微信小程序开发文档,发现创建页面组件用的是Page构造器,创建公共组件用的是Component构造器。然后在Component构造器的lifetimes配置项中,使用与onLoad方法同等作用的attached 方法,发现内部的方法成功调用,拿到表格数据。
结果:成功,表格数据成功渲染。
THERE 知识总结
总结一:小程序创建公共组件。
Component({
// 用于监听 properties 和 data 的变化
behaviors: [],
// 属性定义
properties: {
// 未简化的定义方式
myProperty: {
type: String,
value: ''
},
// 简化的定义方式
myProperty2: String
},
// 数据定义,可用于模板渲染
data: {},
// 组件生命周期声明对象(最重要的生命周期是 created attached detached)
lifetimes: {
// 在组件实例刚刚被创建时执行
created: function () { },
// 在组件实例进入页面节点树时执行
attached: function () { },
// 在组件实例被从页面节点树移除时执行
detached: function () { },
},
// 组件所在页面的生命周期声明对象
pageLifetimes: {
// 页面被展示
show: function () { },
// 页面被隐藏
hide: function () { },
// 页面尺寸变化
resize: function () { },
},
// 组件的方法
methods: {
onMyButtonTap: function(){
this.setData({
// 更新属性和数据的方法与更新页面数据的方法类似
})
},
}
})
总结二:
小程序创建页面组件。
Page({ // 数据定义,可用于模板渲染 data: { text: "This is page data." }, // 监听页面加载 onLoad: function () { }, // 监听页面显示 onShow: : function () { }, // 监听页面初次渲染完成 onReady: : function () { }, // 监听页面隐藏 onHide: : function () { }, // 监听页面卸载 onUnload: : function () { }, // 页面的方法 onTabItemTap () { },})
总结三:
uni中组件onLoad方法不执行解决
uni中,在页面当中引用公共组件时onLoad方法不执行 ,可以使用vue自带生命周期函数created、mounted ,或者使用$refs获取组件中的方法并调用来解决。
FOUR 集思广益
欢迎各位大佬对此类问题留言或私信指教,让大家一起学习提高!
- END -
ABOUT 关于作者
- 宋大狮 | 轻轻松松工作,简简单单生活
- 小唐狮 | 广场舞大军中最靓的仔
猜你喜欢
- 2024-11-03 「大促最后1天」带你了解家庭的生命周期
- 2024-11-03 uniapp-权限处理(uniapp弹出通知权限)
- 2024-11-03 万能前端框架uni app初探03:底部导航开发
- 2024-11-03 uniapp开发安卓应用踩坑记(uniapp开发项目)
- 2024-11-03 uniapp 触底加载更多数据的方法(uniapp上拉加载更多)
- 2024-11-03 《微信小程序开发从入门到实战》学习二十七
- 2024-11-03 uni-app plus.runtime.arguments 获取参数
- 2024-11-03 uniapp入门到进阶(必备知识扩展-1) - vue3你不知道的那些事
- 2024-11-03 遵义小红椒 带你进 uni-app 入坑指南
- 2024-11-03 uni-app从入门到进阶 系统完成项目实战
- 02-21走进git时代, 你该怎么玩?_gits
- 02-21GitHub是什么?它可不仅仅是云中的Git版本控制器
- 02-21Git常用操作总结_git基本用法
- 02-21为什么互联网巨头使用Git而放弃SVN?(含核心命令与原理)
- 02-21Git 高级用法,喜欢就拿去用_git基本用法
- 02-21Git常用命令和Git团队使用规范指南
- 02-21总结几个常用的Git命令的使用方法
- 02-21Git工作原理和常用指令_git原理详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)