uniapp WeChat アプレット: ページ + コンポーネントのライフサイクル シーケンス

uniapp WeChat アプレット: ページ + コンポーネントのライフサイクル シーケンス


この uniapp WeChat アプレット プロジェクトは VUE2を使用します

表紙

ホームページにはジャンプ ボタンのみが用意されています。

<template>
	<view>
		<navigator url="/pages/myPage/myPage?name=jerry" hover-class="navigator-hover">
			<button type="default">跳转到新页面</button>
		</navigator>
	</view>
</template>

<script>
	export default {
      
      
		data() {
      
      return {
      
       }},
	}
</script>

<style>
</style>

ページ

<template>
	<view> 页面 <parent-component>parent-component</parent-component> </view>
</template>

<script>
	export default {
      
      
		data() {
      
      return {
      
       }},
		onInit(option){
      
      console.log(`页面 onInit: ${ 
        JSON.stringify(option)}`)},
		onLoad(option){
      
      console.log(`页面 onLoad: ${ 
        JSON.stringify(option)}`)},
		onShow(option){
      
      console.log(`页面 onShow: ${ 
        JSON.stringify(option)}`)},
		onReady(option){
      
      console.log(`页面 onReady: ${ 
        JSON.stringify(option)}`)},
		onHide(option){
      
      console.log(`页面 onHide: ${ 
        JSON.stringify(option)}`)},
		onUnload(option){
      
      console.log(`页面 onUnload: ${ 
        JSON.stringify(option)}`)},
		onResize(option){
      
      console.log(`页面 onResize: ${ 
        JSON.stringify(option)}`)},
		onPullDownRefresh(option){
      
      console.log(`页面 onPullDownRefresh: ${ 
        JSON.stringify(option)}`)},
		onReachBottom(option){
      
      console.log(`页面 onReachBottom: ${ 
        JSON.stringify(option)}`)},
		onTabItemTap(option){
      
      console.log(`页面 onTabItemTap: ${ 
        JSON.stringify(option)}`)},
		onShareAppMessage(option){
      
      console.log(`页面 onShareAppMessage: ${ 
        JSON.stringify(option)}`)},
		onPageScroll(option){
      
      console.log(`页面 onPageScroll: ${ 
        JSON.stringify(option)}`)},
		onShareTimeline(option){
      
      console.log(`页面 onShareTimeline: ${ 
        JSON.stringify(option)}`)},
		onAddToFavorites(option){
      
      console.log(`页面 onAddToFavorites: ${ 
        JSON.stringify(option)}`)},
	}
</script>

<style>
</style>

親コンポーネント

<template>
	<view> 父组件 <child-component>child-component</child-component> </view>
</template>

<script>
	export default {
      
      
		data() {
      
      return {
      
      };},
		beforeCreate(option){
      
      console.log(`父组件 beforeCreate: ${ 
        option}`)},
		created(option){
      
      console.log(`父组件 created: ${ 
        option}`)},
		beforeMount(option){
      
      console.log(`父组件 beforeMount: ${ 
        option}`)},
		mounted(option){
      
      console.log(`父组件 mounted: ${ 
        option}`)},
		beforeDestroy(option){
      
      console.log(`父组件 beforeDestroy: ${ 
        option}`)},
		destroyed(option){
      
      console.log(`父组件 destroyed: ${ 
        option}`)},
	}
</script>

<style>
</style>

サブアセンブリ

<template>
	<view> 子组件 </view>
</template>

<script>
	export default {
      
      
		data() {
      
      return {
      
      };},
		beforeCreate(option){
      
      console.log(`子组件 beforeCreate: ${ 
        option}`)},
		created(option){
      
      console.log(`子组件 created: ${ 
        option}`)},
		beforeMount(option){
      
      console.log(`子组件 beforeMount: ${ 
        option}`)},
		mounted(option){
      
      console.log(`子组件 mounted: ${ 
        option}`)},
		beforeDestroy(option){
      
      console.log(`子组件 beforeDestroy: ${ 
        option}`)},
		destroyed(option){
      
      console.log(`子组件 destroyed: ${ 
        option}`)},
	}
</script>

<style>
</style>

完全なシーケンス

ここに画像の説明を挿入

// 进入
父组件 beforeCreate: undefined
父组件 created: undefined
父组件 beforeMount: undefined
子组件 beforeCreate: undefined
子组件 created: undefined
子组件 beforeMount: undefined
页面 onLoad: {"name":"jerry"}
页面 onShow: undefined
子组件 mounted: undefined
父组件 mounted: undefined
页面 onReady: undefined

// 退出
页面 onUnload: undefined
子组件 beforeDestroy: undefined
子组件 destroyed: undefined
父组件 beforeDestroy: undefined
父组件 destroyed: undefined

混ぜあわせる

このドキュメントではページとコンポーネントのライフ サイクルを個別にリストしていますが、効果を確認するためにページとコンポーネントにすべてのライフ サイクル関数を追加します。

// 进入
页面的组件生命周期 beforeCreate: undefined
页面的组件生命周期 created: undefined
页面的组件生命周期 beforeMount: undefined
父组件 beforeCreate: undefined
父组件 created: undefined
父组件 beforeMount: undefined
子组件 beforeCreate: undefined
子组件 created: undefined
子组件 beforeMount: undefined
页面 onLoad: {"name":"jerry"}
页面 onShow: undefined
子组件 mounted: undefined
子组件的页面生命周期 onReady: undefined
父组件 mounted: undefined
父组件的页面生命周期 onReady: undefined
页面的组件lifecycle mounted: undefined
页面 onReady: undefined

// 退出
页面 onUnload: undefined
子组件 beforeDestroy: undefined
子组件 destroyed: undefined
父组件 beforeDestroy: undefined
父组件 destroyed: undefined
页面的组件生命周期 beforeDestroy: undefined
页面的组件生命周期 destroyed: undefined

参考文献

uniap ページのライフサイクル
uniap コンポーネントのライフサイクル

おすすめ

転載: blog.csdn.net/jx520/article/details/131961170