IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> autojs声明文件 -> 正文阅读

[开发工具]autojs声明文件

声明文件是什么

声明文件是typescript中的概念, 主要用来描述变量类型,

声明文件不包含实现,它只是类型声明

声明文件的服务对象是谁?

声明文件, 去描述js文件中的变量类型, 给ts用

autojs需要声明文件吗

vscode会把声明文件的内容作为代码提示., 这样就不用查文档了, 这是好处之一;

之前的代码提示是通过代码片段来实现的,

现在的插件把代码片段文件删掉了, 取而代之的就是.d.ts文件

vscode的autojs插件文件路径

C:\Users\Administrator.vscode\extensions\hyb1996.auto-js-pro-ext-1.3.2

从哪里获取autojs的声明文件

打开vscode,按以下步骤操作:

  • 按F1
  • 输入autojsv8
  • 点击Auto.js Pro: 新建V8 API项目(New V8 API Projcet)
  • 选择文件夹, 用来放置项目文件
  • 声明文件就出现了
  • node_modules@autojs\types-pro8\index.d.ts
  • 需要一个tsconfig.json文件, 来指明声明文件在哪里, 字段是: typeRoots

声明文件index.d.ts

d.ts大名叫TypeScript Declaration File

查看该文件, 看看有哪些声明格式:

  • declare module ‘app’ { … }
  • declare var app: AutoJs.App;
  • declare function sleep(n: number);
  • declare namespace AutoJs { … }

并且基本都加了global, 表示这是一个全局声明.

那么我们在vscode中直接写全局声明过的变量, 鼠标放上去, 就可以显示代码提示了,

就不用查文档了呢, 每次节约10秒钟, 算算能节约多长时间.

从上到下依次是

  • 声明模块
  • 声明变量
  • 声明函数
  • 声明命名空间

module和namespace看着好像没什么区别啊, 我就查了一下, 官方文档的解释如下:

A note about terminology: It’s important to note that in TypeScript 1.5, the nomenclature has changed. “Internal modules” are now “namespaces”. “External modules” are now simply “modules”, as to align with ECMAScript 2015’s terminology, (namely that module X { is equivalent to the now-preferred namespace X {).

也就是说module X 等同于 namespace X, 我理解的对不对?
有错请指正.

怎么声明一个函数

我们来看看这个images.save是怎么声明的?

images.save(image, path[, format = “png”, quality = 100])

首先拆解函数

  • 他属于images这个对象
  • 他的名字叫save
  • 他有4个参数, 2个必填参数, 2个默认参数

然后我们在vscode中输入images.save,

鼠标放到images上面, 可以看到以下代码提示
在这里插入图片描述

鼠标放到save上面, 可以看到以下代码提示
在这里插入图片描述

按住ctrl, 再点击images可以看到声明内容

declare var images: AutoJs.Images;

按住ctrl, 再点击save可以看到声明内容, 这就是上面图片中代码提示的全部内容

/**
* 把图片image以PNG格式保存到path中。如果文件不存在会被创建;文件存在会被覆盖。
* ```
* // 把图片压缩为原来的一半质量并保存
* var img = images.read("/sdcard/1.png");
* images.save(img, "/sdcard/1.jpg", "jpg", 50);
* app.viewFile("/sdcard/1.jpg");
* ```
* @param image 图片
* @param path 路径
* @param format 图片格式,可选的值为:
* * `png`
* * `jpeg`/`jpg`
* * `webp`
* @param quality 图片质量,为0~100的整数值
**/
  save(image: Image, path: string, format?: "png" | "jpg" | "jpeg" | "webp", quality?: number);

save四个参数中, path, format, quality的参数类型都是基本类型, string, number, 可选参数用 ?: 表示,

save方法的层级

declare module '__images__' {
    global {
        namespace AutoJs {
            interface Images {
                save( ... );

第一个参数是Image, 我们按住Ctrl, 点击Image看看跳转到哪里了?

Image

class Image {
  getWidth(): number;
  readonly width: number;
  getHeight(): number;
  readonly height: number;
  saveTo(path: string);
  pixel(x: number, y: number): number;
  recycle();
  isRecycled(): boolean;
  readonly mat?: Mat;
  readonly bitmap?: any;
}

Image层级

declare module '__images__' {
  global {
    namespace AutoJs {
      class Image {

图色的声明就放到图色模块里面, 再声明为global, 归属于命名控件AutoJs

Image这个类是专门为了save这个方法的第一个参数来编写的,

save的参数类型基本都是基本类型, 除了Mat, 点击Mat看看在哪里声明的?

type Mat = any;

any, 变量类型终结者.

type用于声明一个变量类型Mat, 其真实类型是any.

一些声明例子

declare var name: string;
declare var age: number;
declare var id: number;
declare const SMALL_TARGET: 1_0000_0000;

declare function getName(): string;
declare function getName(id: string): string;
declare function isSingleDog(name?: string): boolean;

声明模块

foo.d.ts

export let name: string;
export function getNameURL2(num888888: string): string;
namespace student {
  export let name: string;
  export let age: number;
  export function doWhat(what: string): string;
}

foo.js

let name = "yashu666";
function getNameURL2(num) {
  return "numberURL2 is " + num;
}
let student = {
  name: "lucy",
  age: "16",
  doWhat: function (info) {
    console.log("student is doing " + info);
  },
};
module.exports = { name, getNameURL2, student };

main.ts

import URL2 from "./foo/foo";
console.log(URL2);
console.log(URL2.name);
URL2.getNameURL2;
URL2.student.doWhat("homework");

注意

  • foo.d.ts和foo.js要在同一个文件夹
  • main.ts中的代码提示的是foo.d.ts中的内容
  • main.ts运行的是foo.js中的内容

?

名人名言

思路是最重要的, 其他的百度, bing, stackoverflow, github, 安卓文档, autojs文档, 最后才是群里问问
— 牙叔教程

声明

部分内容来自网络
本教程仅用于学习, 禁止用于其他用途

bilibili

牙叔教程

微信公众号 牙叔教程

在这里插入图片描述

QQ群

747748653
在这里插入图片描述

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2021-11-11 12:55:00  更:2021-11-11 12:55:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/23 12:07:08-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码