23:52:42.215/E: TypeError: 无法调用 nul 的方法
get". (file:///android_asset/modules/ ui_js#98)
TypeError: 无法调用 null 的方法"get".
at file:///android _asset/modules/ ui .js:98:0
at 685d3a4c9428186998e86e2d.js:8:0 这个报错是什么原因造成的

已存档
七月CX · 2 个月前
第 1 条补充
·
2 个月前

auto.setMode('fast');
// 显示控制台的悬浮窗
console.show();
// 隐藏输入框和确定按钮
ui.run(function() {
let mConsoleViewField = runtime.console.getClass().getDeclaredField('mConsoleView');
mConsoleViewField.setAccessible(true);
let refConsoleView = mConsoleViewField.get(runtime.console);
let mConsoleView = refConsoleView.get();
mConsoleView.findViewById(com.stardust.autojs.R.id.input_container).visibility = android.view.View.GONE;
}); 在运行这段代码时报错 23:52:42.215/E: TypeError: 无法调用 nul 的方法
get". (file:///android_asset/modules/ ui_js#98)
TypeError: 无法调用 null 的方法"get".
at file:///android _asset/modules/ ui .js:98:0
at 685d3a4c9428186998e86e2d.js:8:0 是什么原因 鸿蒙系统

第 2 条补充
·
2 个月前

给出的这个自定义窗口帮我加一个关闭按钮,方便窗口不需要的时候进行关闭操作

回答

Hamibot AI
1
· 2 个月前

这个报错是因为你试图调用一个为 null 的对象的方法 "get",而这是不允许的。

常见的原因是你在使用 ui 模块时,没有正确初始化 UI 层级结构,或者你在错误的时间访问了尚未创建的 UI 元素。

例如,在以下代码中:

var view = ui.get('myView');
view.get(); // 如果 view 为 null,就会抛出 TypeError

如果 ui.get('myView') 返回 null(即找不到对应 id 的组件),那么调用 .get() 就会出错。

解决方法

  1. 确保已经正确设置 UI 布局
    在调用 ui.get() 之前,必须已经通过 ui.layout() 设置了布局,并且控件有正确的 id。

    示例:

    ui.layout(
        <vertical id="myLayout">
            <text id="myText" text="Hello World"/>
        </vertical>
    );
    
    var textView = ui.get('myText');
    log(textView.text); // 正确获取文本视图
    
  2. 检查控件是否存在

    在访问控件前进行判空处理:

    var view = ui.get('myView');
    if (view !== null) {
        view.get();
    } else {
        toast("控件未找到");
    }
    
  3. 不要在 ui.layout() 之前访问控件

    UI 控件必须在布局定义之后才能访问,否则会返回 null


如果你仍然无法解决问题,可以发送邮件到 support@hamibot.cn 寻求帮助。


补充回答 1

这个报错是因为你在调用 runtime.console 的时候,它可能还没有被正确初始化。

在鸿蒙系统中,某些模块(如 console)是延迟初始化的,也就是说它们只有在第一次使用时才会真正创建。你直接调用了:

let mConsoleViewField = runtime.console.getClass().getDeclaredField('mConsoleView');

此时 runtime.console 还未初始化,返回的是 null,因此调用 .getClass() 就会报错:

TypeError: 无法调用 null 的方法 "getClass"

正确做法

你需要确保在访问 runtime.console 前已经触发了它的初始化。最简单的方式是在之前调用一次 console.show() 或者进行一次 log() 输出,例如:

auto.setMode('fast');

// 触发 console 初始化
console.show();

// 确保 console 已经初始化后再操作隐藏输入框
ui.run(function() {
  try {
    let mConsoleViewField = runtime.console.getClass().getDeclaredField('mConsoleView');
    mConsoleViewField.setAccessible(true);
    let refConsoleView = mConsoleViewField.get(runtime.console);
    let mConsoleView = refConsoleView.get();
    mConsoleView.findViewById(com.stardust.autojs.R.id.input_container).visibility = android.view.View.GONE;
  } catch (e) {
    loge("隐藏输入框失败: " + e);
  }
});

注意事项

  • 鸿蒙系统对 Java 反射支持存在限制,部分 Android 上可用的反射操作可能在鸿蒙上失效。
  • 如果仍然出错,可能是由于运行时环境不一致导致,建议通过自定义悬浮窗方式替代默认控制台(见下方替代方案)。

替代方案:使用自定义悬浮窗控制台(推荐)

auto.setMode('fast');

// 创建自定义悬浮窗控制台
let fw = floaty.rawWindow(
  <vertical w="200" h="200" bg="#80333333">
    <text bg="#000000" textColor="#ffffff">自定义悬浮窗控制台</text>
    <com.stardust.autojs.core.console.ConsoleView id="console"/>
  </vertical>
);

fw.console.setConsole(runtime.console);

// 隐藏输入框和确定按钮
ui.run(function() {
  fw.console.findViewById(com.stardust.autojs.R.id.input_container).visibility = android.view.View.GONE;
});

log('测试。。。');
setTimeout(() => {}, 5000);

这样可以避免与原生控制台相关的兼容性问题。

如果你仍有问题,也可以发送邮件到 support@hamibot.cn 寻求帮助。


补充回答 2

你可以通过添加一个按钮并为其绑定点击事件来实现关闭自定义悬浮窗的功能。以下是修改后的完整代码,新增了一个“关闭”按钮,并绑定了关闭悬浮窗的操作:

auto.setMode('fast');

// 创建自定义悬浮窗控制台
let fw = floaty.rawWindow(
  <vertical w="200" h="200" bg="#80333333">
    <text bg="#000000" textColor="#ffffff">自定义悬浮窗控制台</text>
    <com.stardust.autojs.core.console.ConsoleView id="console"/>
    <button id="closeBtn" text="关闭" layout_gravity="center|bottom" textSize="16sp" margin="10"/>
  </vertical>
);

fw.console.setConsole(runtime.console);

// 隐藏输入框和确定按钮
ui.run(function() {
  fw.console.findViewById(com.stardust.autojs.R.id.input_container).visibility = android.view.View.GONE;
});

// 绑定关闭按钮点击事件
fw.closeBtn.click(function () {
  fw.close(); // 关闭悬浮窗
  hamibot.exit(); // 退出脚本(可选)
});

log('测试。。。');
setTimeout(() => {}, 5000);

功能说明

  • <button>:新增的按钮控件,用于触发关闭操作。
  • fw.closeBtn.click(...):为按钮绑定点击事件,点击后关闭悬浮窗。
  • hamibot.exit():如果你希望在关闭窗口的同时结束脚本运行,可以加上这句;如果不需要脚本退出,可以删除或注释掉。

这样你就可以方便地手动关闭自定义悬浮窗了。

ℹ️ 本回答由 AI 生成,内容仅供参考