|
1 | 1 | import '@abraham/reflection' |
2 | 2 | import { Component, VueComponent } from 'vue3-oop' |
3 | | -import { Inject, InjectionToken, SkipSelf } from 'injection-js' |
4 | 3 | import { createApp } from 'vue' |
5 | 4 | import './theme/app.css' |
6 | | -import { focusDirective } from './focus.directive' |
7 | 5 | import { CountService } from './count.service' |
8 | 6 |
|
9 | | -const TOKEN1 = new InjectionToken('TOken') |
10 | | - |
11 | | -abstract class A { |
12 | | - name = 1 |
13 | | -} |
14 | | - |
15 | | -@Component({ |
16 | | - providers: [ |
17 | | - { provide: TOKEN1, useValue: 1 }, |
18 | | - { provide: A, useValue: { age: 19 } }, |
19 | | - { provide: 'aa', useValue: 1, multi: true }, |
20 | | - { provide: 'aa', useValue: 2, multi: true }, |
21 | | - ], |
22 | | -}) |
| 7 | +@Component() |
23 | 8 | class Home extends VueComponent { |
24 | | - static directives = { |
25 | | - focus: focusDirective, |
26 | | - } |
27 | | - constructor( |
28 | | - @Inject(TOKEN1) private a: any, |
29 | | - private c: CountService, |
30 | | - private d: A, |
31 | | - @Inject('aa') private e: number[], |
32 | | - ) { |
| 9 | + constructor(private countService: CountService) { |
33 | 10 | super() |
34 | | - console.log(a, c, d, e) |
35 | 11 | } |
36 | 12 |
|
37 | 13 | render() { |
38 | 14 | return ( |
39 | | - <div> |
40 | | - 111122222ccc |
41 | | - <HomeChild></HomeChild> |
| 15 | + <div style={{ textAlign: 'center' }}> |
| 16 | + <h2>count: {this.countService.count}</h2> |
| 17 | + <button onClick={() => this.countService.add()}>+</button> |
| 18 | + <button onClick={() => this.countService.remove()}>-</button> |
42 | 19 | </div> |
43 | 20 | ) |
44 | 21 | } |
45 | 22 | } |
46 | 23 |
|
47 | | -@Component() |
48 | | -class HomeChild extends VueComponent { |
49 | | - constructor( |
50 | | - private countService: CountService, |
51 | | - @SkipSelf() private countService1: CountService, |
52 | | - @Inject(TOKEN1) private a: number, |
53 | | - ) { |
54 | | - super() |
55 | | - console.log(countService, countService1, countService === countService1) |
56 | | - console.log(a) |
57 | | - } |
58 | | - |
59 | | - render() { |
60 | | - return <div>2222</div> |
61 | | - } |
62 | | -} |
63 | | - |
64 | 24 | const app = createApp(Home) |
65 | 25 | app.mount('#app') |
0 commit comments