【每日学点鸿蒙知识】Text填充父控件、Native接收数组、js逻辑不执行问题、UIAbility上下文问题、页面跳转路由栈

1、HarmonyOS 如何使Text组件填充满父组件?
build() {
  Row() {
    Row() {
      Text(this.str)
        .constraintSize({ maxWidth: '100%', minHeight: "30vp" })
        .backgroundColor(Color.Gray)
        .fontSize('24vp')
    }
    .key('row1')
    .constraintSize({ maxWidth: '100%'})
    .backgroundColor(Color.Green)
  }
  .key('row2')
  .backgroundColor(Color.Yellow)
  .width('90%')

  Button('add')
    .onClick(() => {
      this.str += 'hello';
    })
  Button('reset')
    .onClick(() => {
      this.str = 'hello';
    })
}

想让row1组件的大小随Text组件的大小变化,当最外层row2宽度放不下时,自动换行,并且完全填充row2容器,但目前在row1外侧总有一段无法被填充的(下图右侧的黄色区域),如何修改可以使row1/Text完全填充row2?

把row2的width去掉就好了,如果需要调节布局可以使用margin

2、HarmonyOS NAPI,如果从ArkTS侧传入Uint8Array,请问Native该怎么接收这个数组?

请参考以下代码

napi_typedarray_type arr_type;
napi_value arr_buffer;
size_t arr_offset;
size_t arr_i, arr_length;
// 获取传入数组的长度和类型
napi_status status = napi_get_typedarray_info(env, arr, &arr_type, &arr_length, NULL, &arr_buffer, &arr_offset);
LOGI("-------arr--%{public}d-------", arr_length);
void *data;
size_t byte_len;
napi_create_array_with_length(env, arr_length, &arr_buffer);
napi_get_arraybuffer_info(env, arr_buffer, &data, &byte_len);
napi_value output_buffer;
void *output_ptr = NULL;
napi_create_arraybuffer(env, byte_len, &output_ptr, &output_buffer);
napi_value out_arr;
napi_create_typedarray(env, arr_type, arr_length, output_buffer, arr_offset, &out_arr);
if (arr_type == napi_uint8_array) {
  uint8_t *input_bytes = (uint8_t *)(data) + arr_offset;
  uint8_t *output_bytes = (uint8_t *)(output_ptr);
  for (arr_i = 0; arr_i < arr_length; arr_i++) {
    OH_LOG_INFO(LOG_APP, "Multiply_for_arraybuffer input_bytes %{public}d", input_bytes[arr_i]);
    output_bytes[arr_i] = (uint8_t)(input_bytes[arr_i] * 1);
    LOGI("最终结果,============%{public}zi", output_bytes[arr_i]);
  }
}
3、HarmonyOS H5页面通过window.open("超链接", "_blank")打开新页面后返回原页面js逻辑不执行?

Web组件如果支持多窗口,即配置了multiWindowAccess为true,则需要在onWindowNew中调用event.handler.setWebController接口,否则会造成Render进程阻塞。应用没有调用event.handler.setWebController接口导致

参考:https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-arkweb/ts-basic-components-web.md#onwindownew9

4、HarmonyOS ts中BaseAbility extends UIAbility:Cannot find name 'Context'.?
export default abstract class BaseAbility extends UIAbility {

  static appContext:common.ApplicationContext;

  onWindowStageCreate(windowStage: window.WindowStage): void {
    BaseAbility.appContext = this.context.getApplicationContext()
    Logger.info('testTag', '%{public}s', 'BaseAbility onWindowStageCreate');
    super.onWindowStageCreate(windowStage)
  }

  static getContext(): common.ApplicationContext {
    return BaseAbility.appContext;
  }
}
5、HarmonyOS 页面跳转的路由栈如何拿到?

获取路由栈信息可以参考:Navigation

NavPathStack是Navigation路由栈,允许被继承。开发者可以在派生类中新增属性方法,也可以重写基类NavPathStack的方法。派生类对象可以替代基类NavPathStack对象使用。提供了下面方法:

相关推荐
Jiaberrr1 小时前
页面转 PDF 功能的实现思路与使用方法
前端·javascript·vue.js·微信小程序·pdf·uniapp
阿珊和她的猫1 小时前
JavaScript中的内存泄露:识别与避免
开发语言·javascript·ecmascript
我是Feri1 小时前
Harmony OS开发-ArkUI框架速成四
harmonyos·arkts·arkui
pchmi1 小时前
C# OpenCV机器视觉:背景减除与前景分离
javascript·opencv·c#
幸运小圣2 小时前
LeetCode热题100-相交链表【JavaScript讲解】
javascript·leetcode·链表
赵大仁2 小时前
Uniapp中使用`wxml-to-canvas`开发DOM生成图片功能
前端·javascript·微信小程序·uni-app
一个处女座的程序猿O(∩_∩)O2 小时前
前端如何判断多个请求完毕
前端·javascript
罗_三金2 小时前
vue3组件化开发优势劣势分析,及一个案例
javascript·css·vue.js·html·vue3
别发呆了吧3 小时前
vue代理问题
前端·javascript·vue.js
Nejosi_念旧3 小时前
编写可复用性的模块
前端·javascript·vue.js