How to pass parameters to the parent page of wechat applets
Sometimes when we do wechat mini program project, we will encounter the following situation: there is a list page, the page has a screening condition, click to jump to the page, select the conditions, after selecting back to the list page, according to the screening conditions for data query. In general, more often than not, what we see is filtering conditions in the form of popboxes. So how do we pass parameters from the child page to the parent page if we want to interact in this way?
The problem
- Wx. navigateBack cannot carry parameters, and child pages cannot pass parameters to parent pages.
Child pages operate on parent page data
Notice here that we’re talking about the child page manipulating the parent page’s data.
There is an API for getCurrentPages in the official documentation:
PageObject[] getCurrentPages() gets the current page stack. The first element in the array is the home page and the last element is the current page.
- Do not attempt to modify the page stack, as this will cause routing and page state errors.
- Don’t in
App.onLaunch
Is called whengetCurrentPages()
At this time,page
It hasn’t been generated yet.
Using the getCurrentPages API, we can get the stack data, so we can get the specified page, in the child page by modifying the parent page data, we can implement the child page to the parent page parameter function.
const pages = getCurrentPages();
const gotoPage = pages[pages.length - 1];
Copy the code
So pages[pages.length-1] is the current page, the parent page is pages[pages.length-2], and so on, we can obtain other ancestor pages.
Then use the setData method gotopage.setData ({XXX: “}) to modify the setting of the parent page data, so as to achieve the purpose of the child page to the parent page parameters. NavigateBack navigateBack to wx.navigateBack
Other solutions
- component
- bounced
As we mentioned at the beginning of this article, if we need to pass parameters from the child page to the parent page, we can display the content in the form of a popbox. After selecting the corresponding data, we can hide the current popbox or component.