- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
嗨,我是 typescript 的新手,对 angular 的经验很少。我一直在尝试使用 typescript 获得一个非常常见的 angular-ui-router 设置,但我无法弄清楚我缺少什么。我有两个嵌套的命名 View ,它们似乎根本无法加载。
app/app.ts
module myModule{
class MyConfig {
constructor( private $stateProvider:ng.ui.IStateProvider,
private $urlRouterProvider:angular.ui.IUrlRouterProvider ) {
this.init();
}
private init():void {
this.$stateProvider.state( 'home',
{
abstract:true,
template: '<main></main>',
url: '/'
}).state('home.main',
{
views: {
'lhp@home': { template: '<lhp></lhp>' },
'rhs@home': { template: '<rhs></rhs>' }
},
url: '/main',
});
this.$urlRouterProvider.otherwise('/main');
}
}
let myApp = angular.module( 'myModule', ['ui.router'] );
myApp.config(['$stateProvider', '$urlRouterProvider', ($stateProvider, $urlRouterProvider) => {
return new MyConfig($stateProvider, $urlRouterProvider);
}]);
主要指令是一个简单的 div,它是两个命名 View 的容器
main.html/main.controller.ts
module app.Controllers {
export class MainController {
constructor( private $log:ng.ILogService ) {
this.Init();
}
private Init() {
this.$log.info('Main Controller');
}
}
angular.module('myModule').controller( 'mainController', ['$log', MainController] );
}
app/components/main.html
<div>
<div id="wrap">
<div id="left_col" ui-view="lhp"></div>
<div id="right_col" ui-view="rhs"></div>
</div>
</div>
app/components/main.directive.ts
module app.Directives {
'use strict';
export class MainDirective implements ng.IDirective {
public templateUrl:string = 'components/main.html';
public restrict:string = 'E';
public controller:string = 'mainController';
public scope = {};
constructor(private $log:ng.ILogService) {
this.$log.info('main directive');
}
public static Factory() {
return (log:ng.ILogService) => {
return new MainDirective(log);
};
}
}
angular.module('myModule').directive('main', ['$log', app.Directives.MainDirective.Factory()]);
}
app/components/lhp.controller.ts
module app.Controllers {
export class LhpController {
constructor( private $log:ng.ILogService ) {
this.Init();
}
private Init() {
this.$log.info('LHP Controller');
}
}
angular.module('myModule').controller( 'lhpController', ['$log', LhpController] );
}
app/components/lhp.html
<div style="width: inherit">
THIS IS A TEST
</div>
app/components/lhp.directive.ts
module app.Directives {
'use strict';
export class LhpDirective implements ng.IDirective {
public templateUrl:string = 'components/lhp.html';
public restrict:string = 'E';
public controller:string = 'lhpController';
public controllerAs:string = 'lctrl';
public scope = {};
constructor(private $log:ng.ILogService) {
this.$log.info('lhp directive');
}
public static Factory() {
return (log:ng.ILogService) => {
return new LhpDirective(log);
};
}
}
angular.module('myModule').directive('lhp', ['$log', app.Directives.LhpDirective.Factory()]);
}
rhs View 的设置与 lhp 完全相同。我已经确认 rhs 和 lhp 指令都可以正常工作,方法是使 home 状态成为非抽象状态并将它们加载为模板。两者都正确呈现。当我将家庭状态抽象化时,就是我遇到问题的时候。主 Controller 更不用说 html 根本不加载。 typescript 和抽象 View 有问题吗?有没有人遇到过 typescript 和嵌套命名 View 的类似问题?我在互联网上搜索了类似的例子,但找不到任何相关的东西。我发现的最接近的例子是:How can I add ui-router stateProvider configuration to my application with Typescript?它显示了抽象 View 应该可以使用 typescript ,但示例没有填写详细信息。我是否遗漏了嵌套命名 View 与 typescript 一起使用的内容?
如有任何帮助,我们将不胜感激。
最佳答案
我的同事发现了这个问题。这是一个 super 简单的修复。这个问题是由于我的抽象 View 中有一个 url 字段引起的:
private init():void {
this.$stateProvider.state( 'home',
{
abstract:true,
template: '<main></main>'
}).state('home.main',
{
views: {
'lhp@home': { template: '<lhp></lhp>' },
'rhs@home': { template: '<rhs></rhs>' }
},
url: '/main',
});
this.$urlRouterProvider.otherwise('/main');
}
关于angularjs - 带有 typescript 的angular-ui-router嵌套命名 View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35543729/
我已经写了并且 npm 发布了这个:https://github.com/justin-calleja/pkg-dependents 现在我正在用 Typescript 编写这个包:https://g
我有一个函数,我想在 TypeScript 中模拟它以进行测试。在我的测试中,我只关心 json和 status .但是,当使用 Jest 的 jest.spyOn 时我的模拟函数的类型设置为返回 h
我正在使用一个库 (Axios),它的包中包含 Typescript 声明。 我想声明一个将 AxiosResponse(在库的 .d.ts 文件中声明)作为参数的函数。我有以下内容: functio
我是 Typescript 的新手。我想使用 将一个 Typescript 文件加载到另一个 Typescript 文件中标签。 我做了一些事情,但它不起作用!请帮助我。 first.ts: imp
为什么我会收到下面屏幕截图中显示的错误? Atom 说我的 tsconfig.json“项目文件包含无效选项”用于 allowJs、buildOnSave 和 compileOnSave。 但是应该允
所以我正在创建一个 TypeScript 库,我可以轻松地将所有生成的 JS 文件编译成一个文件。有没有办法将所有 .ts 和 .d.ts 编译成一个 .ts 文件? 除了支持 JS 的版本(较少的智
Microsoft Research 提供了一种名为Safer TypeScript 的新 TypeScript 编译器变体: http://research.microsoft.com/en-us/
我需要这个来在单个文件中分发 TypeScript 中的库。有没有办法将多个 typescript 文件合并到(一个js文件+一个 typescript 定义)文件中? 最佳答案 要创建一个库,您可以
用例:我想知道一个函数在 typescript 中执行需要多少时间。我想为此目的使用装饰器。我希望装饰器应该返回时间以便(我可以进一步使用它),而不仅仅是打印它。 例如: export functio
我想检查一个类型是否可以为 null,以及它是否具有值的条件类型。 我尝试实现 type IsNullable = T extends null ? true : false; 但是好像不行 type
我的问题是基于这个 question and answer 假设我们有下一个代码: const myFn = (p: { a: (n: number) => T, b: (o: T) => v
我知道双重否定前缀,我知道 TypeScript 的单后缀(非空断言)。 但是这个双后缀感叹号是什么? /.*验证码为(\d{6}).*/.exec(email.body!!)!![1] 取自here
我正在使用以下文件结构在 Webstorm 中开发一个项目 | src | ... | many files | types | SomeInterface |
在 TypeScript 类中,可以为属性声明类型,例如: class className { property: string; }; 如何在对象字面量中声明属性的类型? 我试过下面的代码,但它
我正在寻找一种在不丢失推断类型信息的情况下将 TypeScript 中的文字值限制为特定类型的好方法。 让我们考虑一个类型Named,它保证有一个名字。 type Named = { name:
在 TypeScript 中,我想创建一个联合类型来表示属于一个或多个不同类型的值,类似于 oneOf在 OpenAPI或 JSON Schema .根据a previous answer on a
type Func = (foo:string) => void // function expression const myFunctionExpression:Func = function(f
假设我有一个联合类型,我正在使用类似 reducer 的 API 调用模式,看起来像这样: type Action = { request: { action: "create
我在 typescript 中有以下去抖功能: export function debounce( callback: (...args: any[]) => void, wait: numb
在 Vue3 的 defineComponent 函数中,第一个泛型参数是 Props,所以我在这里使用 Typescript 接口(interface)提供我的 props 类型。喜欢: expor
我是一名优秀的程序员,十分优秀!