ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

autojs声明文件

2021-11-10 22:59:12  阅读:238  来源: 互联网

标签:文件 string number ts autojs save 声明 declare


声明文件是什么

声明文件是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
在这里插入图片描述

标签:文件,string,number,ts,autojs,save,声明,declare
来源: https://blog.csdn.net/snailuncle2/article/details/121258771

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有