声明文件是typescript中的概念, 主要用来描述变量类型,
声明文件不包含实现,它只是类型声明
声明文件, 去描述js文件中的变量类型, 给ts用
vscode会把声明文件的内容作为代码提示., 这样就不用查文档了, 这是好处之一;
之前的代码提示是通过代码片段来实现的,
现在的插件把代码片段文件删掉了, 取而代之的就是.d.ts文件
C:\Users\Administrator.vscode\extensions\hyb1996.auto-js-pro-ext-1.3.2
打开vscode,按以下步骤操作:
d.ts大名叫TypeScript Declaration File
查看该文件, 看看有哪些声明格式:
并且基本都加了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-preferrednamespace X {
).
也就是说module X 等同于 namespace X, 我理解的对不对?
有错请指正.
我们来看看这个images.save是怎么声明的?
images.save(image, path[, format = “png”, quality = 100])
首先拆解函数
然后我们在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看看跳转到哪里了?
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");
思路是最重要的, 其他的百度, bing, stackoverflow, github, 安卓文档, autojs文档, 最后才是群里问问
— 牙叔教程
部分内容来自网络
本教程仅用于学习, 禁止用于其他用途
牙叔教程
747748653