Loading [MathJax]/jax/input/TeX/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何在TypeScript中使用OverlayScrollbars?

如何在TypeScript中使用OverlayScrollbars?
EN

Stack Overflow用户
提问于 2019-11-20 23:40:58
回答 1查看 586关注 0票数 1

我正在使用ASP.NET Core 3.0项目和VS 2019集成开发环境学习TypeScript。我已经使用npmhttps://kingsora.github.io/OverlayScrollbars/#!overview下载了OverlayScrollbars插件。

代码语言:javascript
运行
AI代码解释
复制
npm install overlayscrollbars
npm install @types/overlayscrollbars

下面是一个非常简单的用法示例:

代码语言:javascript
运行
AI代码解释
复制
/// <reference path="../../libs/npm/@types/overlayscrollbars/index.d.ts" />

import OverlayScrollbars from "../../libs/npm/@types/overlayscrollbars/index"; // ../../libs/npm/overlayscrollbars/js/overlayscrollbars.js

$(() => {
    OverlayScrollbars($("body")[0], { });
    //$("body").overlayScrollbars({ });
});

解决方案被编译,文件被转译(目标被更改为注释中的目标-尽管有一天我会问关于转译的问题),并复制到wwwroot。此时,文件被正确引用。

这是我的tsconfig.json文件:

代码语言:javascript
运行
AI代码解释
复制
{
  "compileOnSave": true,
  "compilerOptions": {
    "allowSyntheticDefaultImports": true,
    "esModuleInterop": true,
    "noEmitOnError": true,
    "noImplicitAny": true,
    "skipLibCheck": true,
    "sourceMap": true,
    "target": "es6",
    "typeRoots": [ "node_modules/@types/**" ]
  },
  "exclude": [
    "node_modules",
    "**/*.spec.ts"
  ]
}

有了这个:OverlayScrollbars($("body")[0], { });,我将在运行时获得Uncaught SyntaxError: The requested module does not provide an export named 'default'

对于第二个($("body").overlayScrollbars({ });),我得到了编译错误TS2345: (TS) Argument of type '{}' is not assignable to parameter of type string和一些奇怪的智能感知问题:

C#解决这个问题可能很简单,但是我没有足够的TS知识去做。试图通过试错来解决它并不是很有效率。

下面是一个重现这个问题的极简主义项目:

https://mega.nz/#!9vYGCS6Q!p_jfFXYSo_1yH63UsSWqwsypC_2Lclg57LhirZfdiGI

会非常感谢任何人的帮助。

//编辑1

@Kewin Dousse

我很抱歉我没有清楚地说明它,我之所以明确地引用声明,是因为我在.cshtml文件中导入了实际的文件。

代码语言:javascript
运行
AI代码解释
复制
<link href="~/libs/npm/overlayscrollbars/css/OverlayScrollbars.css" rel="stylesheet" />
...
<script src="~/libs/npm/overlayscrollbars/js/jquery.overlayScrollbars.js"></script>

我特别这样做是为了避免我在这里写的这些问题,无论我是尝试使用OVerlayScrollbarsJQuery还是Vanilla版本都无关紧要。

据我所知,对于导入,如果我想让它工作,浏览器需要指向具有显式.js扩展名的JavaScript文件。

为了解决这个问题,我让gulp用注释中的路径替换d.ts文件的实际路径。

如果我这样做:

代码语言:javascript
运行
AI代码解释
复制
import OverlayScrollbars from "../../libs/npm/@types/overlayscrollbars/index"; // ../../libs/npm/overlayScrollbars/js/jquery.overlayScrollbars.js

我在.ts文件中收到编辑器警告:

和运行时的错误:

如果我这样做:

代码语言:javascript
运行
AI代码解释
复制
import { OverlayScrollbars } from "../../libs/npm/@types/overlayscrollbars/index"; // ../../libs/npm/overlayScrollbars/js/jquery.overlayScrollbars.js

我得到了编译错误TS2305的一个非常奇怪的路径:

如果我这样做:

代码语言:javascript
运行
AI代码解释
复制
import * as OverlayScrollbars from "../../libs/npm/@types/overlayscrollbars/index"; // ../../libs/npm/overlayScrollbars/js/jquery.overlayScrollbars.js

我收到编译错误TS2349

以及以下intellisense错误:

(如果你想知道的话,潜在的VS修复方法是将路径转换为import OverlayScrollbars from "../../libs/npm/@types/overlayscrollbars/index"; )

我真正能让它工作的唯一方法是自己编写JQuery扩展的声明:

代码语言:javascript
运行
AI代码解释
复制
interface JQuery {
    overlayScrollbars(
        options: OverlayScrollbars.Options,
        extensions?: OverlayScrollbars.Extensions
    ): JQuery;
    overlayScrollbars(
        filter?: string | ((element: Element, instance: OverlayScrollbars) => boolean)
    ): OverlayScrollbars | OverlayScrollbars[] | undefined;
}

这样命名:

代码语言:javascript
运行
AI代码解释
复制
$("body").overlayScrollbars({ });

和删除模块导入

我知道这也是声明文件应该做的事情,通过检查它的内容,它似乎是这样做的,但我不能让它工作。

EN

回答 1

Stack Overflow用户

发布于 2019-11-22 09:29:23

这里的问题是,你没有在你的文件中导入OverlayScrollbars的实际代码,你目前只导入了它的类型定义。

在类型定义上:"../../libs/npm/@types/overlayscrollbars/index"引用了@types/overlayscrollbars npm包,这是一个只包含declaration files的npm包(即@types/下的所有包)。声明文件是将TypeScript类型添加到JavaScript库中的文件,以便可以在TypeScript中有效地使用它们。这意味着,因为它们只声明类型,所以没有一个JavaScript行将在那里执行。

在这里,您导入了overlayscrollbars包的声明文件,这使得TypeScript能够理解该JS库的类型。但是,您从未真正导入过库代码本身。

您应该像编写JS一样导入库。我不知道这个库具体导出了什么,但它应该是这样的:

代码语言:javascript
运行
AI代码解释
复制
import OverlayScrollbars from "../../libs/npm/overlayscrollbars";

如果不起作用,也可以试试这个:

代码语言:javascript
运行
AI代码解释
复制
import { OverlayScrollbars } from "../../libs/npm/overlayscrollbars";

还有这个:

代码语言:javascript
运行
AI代码解释
复制
import * as OverlayScrollbars from "../../libs/npm/overlayscrollbars";

因为模块可能尝试以不同的方式导出其符号。(如果不进入lib的导出并实际看到它们的样子,我就无法判断)

第二个错误只是告诉您调用overlayscrollbars的方式是错误的,并且第一个参数应该是string

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58965077

复制
相关文章
SpringBoot 创建可执行Jar
  我们也可以通过插件创建一个在生产环境中运行的可执行jar文件来完成我们的示例。
2019/02/21
1K0
SpringBoot 创建可执行Jar
maven打包可执行jar文件运行报错
项目中同时依赖了Spring和MyBatis,并使用mybatis-spring集成MyBatis和Spring。 使用maven打包为可执行jar文件运行,打包插件为:maven-shade-plugin。
编程随笔
2019/09/11
2.2K0
Intellij idea打带Manifest文件的jar包(可执行jar包)
老版本Intellij idea可以很方便地打带Manifest文件的jar包,也就是可行性的Jar包。今天使用新版的Intellij idea打jar包时遇到了坑,jar包中竟然没有MANIFEST文件。
程裕强
2019/05/27
4.8K0
Spring Boot Maven 打包可执行Jar文件!
Maven pom.xml 必须包含 [plain] view plain copy <packaging>jar</packaging>   [html] view plain copy <build>   <plugins>   <plugin>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-maven-plugin</artifactId>   <configuration>   <fo
庞小明
2018/07/06
9640
【Maven】maven打包生成可执行jar文件
maven默认打包生成的jar是不能够直接运行的,因为在jar文件的META-INF/MANIFEST.MF文中没有Main-Class一行,为了生成可执行的jar文件,需要借助maven的插件,maven-shade-plugin,配置该插件如下:
全栈程序员站长
2022/09/01
1K0
Java -jar参数详解:掌握Java可执行JAR文件的运行技巧
作为一种常用的开发语言,Java经常使用可执行的JAR(Java Archive)文件来打包和分发应用程序。使用java -jar命令运行JAR文件是一种方便快捷的方式。本文将详细介绍java -jar命令的各种参数,帮助您充分利用这个功能。
修己xj
2023/08/25
3.7K0
Java -jar参数详解:掌握Java可执行JAR文件的运行技巧
包和 jar 文件的创建
在之前的文章中,讲到了面向的 3 大特性(封装、继承、多态)和面向对象设计的 5 大原则(SRP、OCP、LSP、DIP、ISP)。此外,我们还讲了如何创建一个类,并且在创建类后如何构造一个对象。然后还介绍了类中的属性和方法,并对构造方法和引用也做了简单的讲解。
村雨遥
2022/10/28
9110
包和 jar 文件的创建
制作可自运行的jar可执行文件
今天看到有人把Java的jar包制作成一个可执行文件,于是乎我也试了一把,确实也挺简单的,记录一下。
kongxx
2018/11/09
1.5K0
Maven编译可执行jar包
文章目录 拷贝lib的jar,配置可执行main函数 拷贝lib的jar <plugin> <artifactId>maven-dependency-plugin</artifactId> <version>2.6</version> <executions> <execution> <id>copy-dependencies</id> <phase>package</phase> <goa
白凡
2018/08/07
8790
Intellij 打可执行jar包
如题,想使用Intellij 打可执行jar包,在网上搜索了很多解决方案,不是很麻烦就是尝试失败。其实,可执行的jar包无非是在MAINFEST.MF多一个配置项而已。那么用最直接的解决方法即可。
程序新视界
2022/05/06
5640
SpringBoot系列-- jar可执行原理
文章篇幅较长,但是包含了SpringBoot 可执行jar包从头到尾的原理,请读者耐心观看。
田维常
2020/02/13
9420
Linux下创建可执行bin安装文件
1、简化操作。一般的软件安装过程,如果想要精简步骤,我们一般会将需要在命令行中输入的命令写成一个脚本,同时将安装介质准备好。我们将脚本和安装介质上传到生产环境,然后通过执行脚本来完成安装。如果能够将这两个文件合并为一个可执行文件,那安装的过程就更简单明了。
大江小浪
2018/07/24
9.2K0
Linux下创建可执行bin安装文件
使用Intellij Idea生成可执行文件jar,开关exe文件步骤
步骤一:打开File -> Project Structure -> Artifacts,例如以下图
全栈程序员站长
2022/07/05
1.3K0
使用Intellij Idea生成可执行文件jar,开关exe文件步骤
【IntelliJ IDEA】导出可执行 JAR 包
选择 " 菜单栏 / File / New / Project " 选项 , 创建新应用 ,
韩曙亮
2023/03/29
3.9K0
【IntelliJ IDEA】导出可执行 JAR 包
解决maven下载的jar文件乱码问题
1.修改Eclipse中文本文件的默认编码:windows->Preferences->general->Workspace->Text file encoding设置为UTF-8 image.png
用户1437675
2020/05/18
8180
解决maven下载的jar文件乱码问题
Maven 生成打包可执行jar包
最近IDEA打可执行Jar包搞了三天,一直失败,好好学习一下Maven-assembly,在此记录一下
全栈程序员站长
2022/09/02
2.3K1
如何将Spring Boot应用程序打包为可执行的jar文件?
🏆本文收录于 《Spring Boot从入门到精通》 ,专门攻坚指数提升,2023 年国内最系统+最强(更新中)。
bug菌
2023/10/15
2.6K0
如何将Spring Boot应用程序打包为可执行的jar文件?
从源代码到可执行文件
在理解一个源代码是如何成为可执行文件时,我简单的回顾下硬件层面、操作系统层面的知识。
全栈程序员站长
2022/07/15
3270
springBoot 怎么利用maven 创建可以执行的jar文件?
1 为了可以使用maven 创建可执行的jar文件 ,首先需要再pom.xml 加入如下的依赖。
爱明依
2019/03/12
1K0
Linux系统创建可执行文件软链接
由于创建软链接这个事情,在算法开发的日常中使用到的并不是很多,因此本文也是做一个简单的回顾。这里我们使用的案例是通过TMalign这个蛋白质打分文件,在编译好可执行文件之后,可以使用建立软链接的方法快捷的使用该可执行文件。
DechinPhy
2022/05/09
2.8K0

相似问题

scala :从scala文件创建jar

10

从Scala文件创建jar文件

94

创建可执行jar文件时遇到的问题

10

Scala,jar文件的问题

21

从jar创建可执行文件

45
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文