HarmonyOS 模板快载demo

HarmonyOS 模板快载demo。

HarmonyOS
2024-10-12 11:55:29
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
superinsect

pages->Index.ets

import { PageWeb, WebInfo } from "./PageWeb"  
import { PageWeb2 } from "./PageWeb2"  
import web_webview from '@ohos.web.webview';  
const targetPageURL =  
  "https://m.ly.com/minsu/houselist?city=2301&filterList=8888_1&inDate=2024-05-26&outDate=2024-05-27&pageSize=20&cityName=成都&resourceType=3"  
@Entry  
@Component  
struct Index {  
  @State message: string = '';  
  @Provide('pageInfos') pageInfos: NavPathStack = new NavPathStack()  
  @Builder  
  PageMap(name: string) {  
    if (name === "pageOne") {  
      PageWeb()  
    } else {  
      PageWeb2()  
    }  
  }  
  build() {  
    Navigation(this.pageInfos) {  
      Row() {  
        Column() {  
          Text(this.message)  
            .fontSize(50)  
            .fontWeight(FontWeight.Bold)  
          Button("模板快载").onClick(() => {  
            // 跳转到page1  
            this.pageInfos.pushPath({ name: 'pageOne', param: { url: targetPageURL } as WebInfo })  
          })  
          Button("非模板快载").onClick(() => {  
            // 跳转到page2  
            this.pageInfos.pushPath({ name: 'page', param: { url: targetPageURL } as WebInfo })  
          })  
        }  
        .width('100%')  
      }  
      .height('100%')  
    }.title('NavIndex').navDestination(this.PageMap)  
  }  
}

pages->PageWeb.ets

import { TemplateWebNode, getManage } from "../TemplateLoad/templateNode"  
import web_webview from '@ohos.web.webview';  
export interface WebInfo {  
  url: string  
}  
@Component  
export struct PageWeb {  
  @Consume('pageInfos') pageInfos: NavPathStack;  
  @State node?: TemplateWebNode = undefined;  
  url?: string  
  controller: web_webview.WebviewController = new web_webview.WebviewController()  
  
  aboutToAppear() {  
    const params = this.pageInfos.getParamByName("pageOne") as WebInfo[];  
    this.url = params[0].url  
    setTimeout(() => {  
      this.controller.runJavaScript(`document.getElementsByClassName("box-btn")[0].click()`);  
    }, 10)  
  }  
  getNode(): TemplateWebNode {  
    if (this.node) {  
      return this.node  
    }  
    const manager = getManage()  
    const template = manager.getTemplate();  
    this.node = template.node  
    this.controller = template.controller  
    return this.node  
  }  
  build() {  
    NavDestination() {  
      Row() {  
        NodeContainer(this.getNode())  
          .height("100%")  
          .width("100%")  
      }  
      .width('100%')  
      .height('100%')  
    }.onBackPressed(() => {  
      if (this.controller.getUrl() === this.url) {  
        this.controller.backward()  
        return true  
      }  
      return false  
    })  
  }  
}

pages->PageWeb2.ets

import { TemplateWebNode, getManage } from "../TemplateLoad/templateNode"  
import web_webview from '@ohos.web.webview';  
export interface WebInfo {  
  url: string  
}  
@Component  
export struct PageWeb2 {  
  @Consume('pageInfos') pageInfos: NavPathStack;  
  @State node?: TemplateWebNode = undefined;  
  controller: web_webview.WebviewController = new web_webview.WebviewController()  
  @State url: string = ""  
  aboutToAppear() {  
    const params = this.pageInfos.getParamByName("page") as WebInfo[];  
    this.url = params[0].url  
  }  
  build() {  
    NavDestination() {  
      Row() {  
        Web({ src: this.url, controller: this.controller }).fileAccess(true).domStorageAccess(true)  
      }  
      .width('100%')  
      .height('100%')  
    }  
  }  
}

TemplateLoad->index.ets

import { UIContext } from '@ohos.arkui.UIContext';  
interface OfflineNode<T, S> {  
  node: T,  
  controller: S  
}  
export class TemplateManage<T, S> {  
  uiContext: UIContext  
  templateList: OfflineNode<T, S>[] = []  
  cratedFactory: (uIContext: UIContext) => [T, S]  
  constructor(uiContext: UIContext, cratedFactory: (uIContext: UIContext) => [T, S]) {  
    this.cratedFactory = cratedFactory  
    this.uiContext = uiContext  
    this.initTemplate()  
  }  
  initTemplate() {  
    const nodeAndController: [T, S] = this.cratedFactory(this.uiContext)  
    this.templateList.push({  
      node: nodeAndController[0], controller: nodeAndController[1]  
    })  
  }  
  getTemplate(): OfflineNode<T, S> {  
    if (!this.templateList[0]) {  
      this.initTemplate()  
    }  
    const firstNode = this.templateList[0]  
    this.templateList.shift()  
    setTimeout(() => {  
      if (!this.templateList[0]) {  
        this.initTemplate()  
      }  
    }, 2000)  
    return firstNode  
  }  
}

TemplateLoad->templateNode.ets

import web_webview from '@ohos.web.webview';  
import { UIContext } from '@ohos.arkui.UIContext';  
import { NodeController, BuilderNode, FrameNode } from '@ohos.arkui.node';  
import { TemplateManage } from "./index"  
interface WebBuildParam {  
  controller: web_webview.WebviewController  
}  
@Builder  
function WebBuilder(param: WebBuildParam) {  
  Column() {  
    Web({ src: "", controller: param.controller })  
      .fileAccess(true)  
      .domStorageAccess(true)  
      .width("100%")  
      .height("100%")  
      .onPageBegin(() => {  
        param.controller.runJavaScript("var hkj_pushState = history.pushState")  
      })  
  }  
}  
const WebBuildFactory = wrapBuilder<WebBuildParam[]>(WebBuilder);  
export class TemplateWebNode extends NodeController {  
  private rootNode: BuilderNode<WebBuildParam[]> | null = null;  
  dispose() {  
    this.rootNode?.getFrameNode()?.dispose()  
  }  
  aboutToDisappear() {  
    this.dispose()  
    return this;  
  }  
  // 必须要重写的方法,用于构建节点数、返回节点挂载在对应NodeContianer中  
  // 在对应NodeContianer创建的时候调用、或者通过rebuild方法调用刷新  
  makeNode(uiContext: UIContext): FrameNode | null {  
    console.log(" uicontext is undifined : " + (uiContext === undefined));  
    if (this.rootNode != null) {  
      // 返回FrameNode节点  
      return this.rootNode.getFrameNode();  
    }  
    // 返回null控制动态组件脱离绑定节点  
    return null;  
  }  
  // 此函数为自定义函数,可作为初始化函数使用  
  // 通过UIContext初始化BuilderNode,再通过BuilderNode中的build接口初始化@Builder中的内容  
  initWeb(uiContext: UIContext, control: WebviewController) {  
    if (this.rootNode != null) {  
      return;  
    }  
    // 创建节点,需要uiContext  
    this.rootNode = new BuilderNode(uiContext)  
    // 创建动态Web组件  
    this.rootNode.build(WebBuildFactory, { controller: control })  
  }  
}  
const TEMPLATE_URL = "https://m.ly.com/minsu/minsuhome"  
export function createTemplateNode(uiContext: UIContext): [TemplateWebNode, web_webview.WebviewController] {  
  // 创建NodeController  
  let templateNode = new TemplateWebNode();  
  let controller = new web_webview.WebviewController();  
  templateNode.initWeb(uiContext, controller);  
  setTimeout(() => {  
    controller.loadUrl(TEMPLATE_URL)  
  }, 100)  
  return [templateNode, controller]  
}  
export let manage: TemplateManage<TemplateWebNode, web_webview.WebviewController>  
export function getManage(): TemplateManage<TemplateWebNode, web_webview.WebviewController> {  
  return manage  
}  
export function startTemplate(uiContext: UIContext) {  
  try {  
    manage = new TemplateManage<TemplateWebNode, web_webview.WebviewController>(uiContext, createTemplateNode)  
  } catch (e) {  
    console.log('hkj', e)  
  }  
}

EntryAbility.ets

import { AbilityConstant, UIAbility, Want } from '@kit.AbilityKit';  
import { hilog } from '@kit.PerformanceAnalysisKit';  
import { window } from '@kit.ArkUI';  
import { startTemplate } from "../TemplateLoad/templateNode"  
export default class EntryAbility extends UIAbility {  
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {  
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');  
  }  
  onDestroy(): void {  
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy');  
  }  
  onWindowStageCreate(windowStage: window.WindowStage): void {  
    // Main window is created, set main page for this ability  
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate');  
    windowStage.loadContent('pages/Index', (err) => {  
      startTemplate(windowStage.getMainWindowSync().getUIContext())  
      if (err.code) {  
        hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? '');  
        return;  
      }  
      hilog.info(0x0000, 'testTag', 'Succeeded in loading the content.');  
    });  
  }  
  onWindowStageDestroy(): void {  
    // Main window is destroyed, release UI related resources  
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy');  
  }  
  onForeground(): void {  
    // Ability has brought to foreground  
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');  
  }  
  onBackground(): void {  
    // Ability has back to background  
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');  
  }  
}
分享
微博
QQ
微信
回复
2024-10-12 17:21:45
相关问题
HarmonyOS 页面传递
246浏览 • 2回复 待解决
HarmonyOS登获取实名信息问题
23浏览 • 1回复 待解决
HarmonyOS 有没有模块化开发模板
418浏览 • 1回复 待解决
3516下提示node.lib问题
8553浏览 • 2回复 已解决
HarmonyOS 申请ACL权限有无模板
88浏览 • 1回复 待解决
怎样能把应用完全关闭
8418浏览 • 1回复 待解决
Redis 模板的分布式锁
3098浏览 • 1回复 待解决
HMOS区隔元素模板在哪儿?
4324浏览 • 1回复 待解决
onehop Device Ability 这个模板咋不见了?
4258浏览 • 1回复 待解决
鸿蒙以后会出Python的开发模板吗?
7346浏览 • 2回复 待解决
HarmonyOS 资讯类demo
254浏览 • 1回复 待解决
HarmonyOS应用更新demo
324浏览 • 1回复 待解决
HarmonyOS 帧动画demo
53浏览 • 1回复 待解决
HarmonyOS viewModal demo问题
398浏览 • 1回复 待解决
HarmonyOS 全局弹窗demo
62浏览 • 1回复 待解决
HarmonyOS 加解密 demo
488浏览 • 1回复 待解决
自定义文件模板失效怎么办啊?
390浏览 • 1回复 待解决
HarmonyOS 商城类应用demo
327浏览 • 1回复 待解决
HarmonyOS 上传文件相关Demo
495浏览 • 1回复 待解决