Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Introduction to ExtReact, ExtAngular and ExtWeb...
Search
Olga
June 06, 2019
Programming
99
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Introduction to ExtReact, ExtAngular and ExtWebComponents
Olga
June 06, 2019
More Decks by Olga
See All by Olga
Visual Feature Engineering for Machine Learning with React
olgapetrova
0
290
Visual Feature Engineering for ML with React and TensorFlow.js
olgapetrova
0
99
How to Re-Architect a JavaScript Class System
olgapetrova
0
140
Web Push Notifications
olgapetrova
1
320
How to add D3.js visualization to your Ext JS application
olgapetrova
1
630
Turbo-charged Data Analysis and Visualization using Ext JS 6.2
olgapetrova
3
130
ExtJS 6: one framework for all devices
olgapetrova
1
810
Other Decks in Programming
See All in Programming
メソッドのジェネリクスでGoの夢は広がるか? / Kyoto.go #65
utgwkk
3
850
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
7k
そのテスト、説明できますか?~LWテスト戦略FW~のご紹介
nakahara
0
150
Even G2とAWSで推しのエージェントを召喚しよう!
har1101
1
120
Contextとはなにか
chiroruxx
1
330
Performance Engineering for Everyone
elenatanasoiu
0
180
RTSPクライアントを自作してみた話
simotin13
0
620
AI 輔助遺留系統現代化的經驗分享
jame2408
1
810
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
4.3k
1B+ /day規模のログを管理する技術
broadleaf
0
100
技術的負債解消で開発者の未来を開く- AIの力でコード刷新
kmd2kmd
0
110
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
270
Featured
See All Featured
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
200
Claude Code のすすめ
schroneko
67
230k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
123
22k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
170
Test your architecture with Archunit
thirion
1
2.3k
VelocityConf: Rendering Performance Case Studies
addyosmani
333
25k
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
250
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
270
What the history of the web can teach us about the future of AI
inesmontani
PRO
1
620
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
160
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
71
40k
Transcript
Olga Petrova, @tyoushe Introduction to ExtReact, ExtAngular, ExtWebComponents Olga Petrova,
@tyoushe
[email protected]
Olga Petrova, @tyoushe ExtReact & ExtAngular
Olga Petrova, @tyoushe
Olga Petrova, @tyoushe Components
Olga Petrova, @tyoushe Ext JS, React and Angular Ext JS
Component configs items: [] Angular Component properties Children elements React Component props Children elements
Olga Petrova, @tyoushe Reactor Wrapper Concept Ext JS Component props
state method calls event listeners transform translate configs events methods link to Ext JS Component
Olga Petrova, @tyoushe Architecture first and lastname React Framework Core
Ext Modern Components Theme Packages Sencha Themer Angular Framework Sencha Test Premium Packages
Olga Petrova, @tyoushe ExtReact 8 import React, { Component }
from 'react'; import { Grid, Column } from '@sencha/ext-modern'; export default class MyGrid extends Component { store = Ext.create('Ext.data.Store', {...}); render() { return ( <Grid title="Stock Prices" store={this.store}> <Column text="Company" dataIndex="name" width="150"/> <Column text="Price" width="85" dataIndex="price" formatter='usMoney‘/> </Grid> ) } } MyGrid.js
Olga Petrova, @tyoushe <container padding="10" layout="fit" [fitToParent]="true"> <grid title="Stock Prices"
[store]="store"> <column text="Company" width="150" dataIndex="name"></column> <column text="Price" width="85" dataIndex="price" formatter="usMoney"></column> <column text="Last Updated" dataIndex="lastChange"></column> </grid> </container> ExtAngular 9 import { Component } from '@angular/core'; @Component({ selector: 'basicgrid-component‘, templateUrl: './MyGrid.html' }) export class BasicGridComponent { store = Ext.create('Ext.data.Store', {...}) constructor() { //... } } MyGrid.html MyGrid.ts
Olga Petrova, @tyoushe Getting Started 10 ExtReact Trial: https://www.sencha.com/products/extreact/evaluate/ ExtAngular
Trial: https://www.sencha.com/products/extangular/evaluate/
Olga Petrova, @tyoushe npm login --registry=https://npm.sencha.com --scope=@sencha npm install -g
@sencha/ext-react-gen ext-react-gen app -i Setup 11
Olga Petrova, @tyoushe Examples 12 ExtReact Kitchensink: https://examples.sencha.com/ExtReact/6.7.0/kitchensink/ ExtAngular Kitchensink:
https://examples.sencha.com/ExtAngular/6.7.0/kitchensink/
Olga Petrova, @tyoushe Vue.js
Olga Petrova, @tyoushe WebComponents
Olga Petrova, @tyoushe
Olga Petrova, @tyoushe Specifications • Custom Elements • Shadow DOM
• ES Modules • HTML Template 16
Olga Petrova, @tyoushe Custom HTML Tag 17 class MyAwesomeButton extends
HTMLElement {...} window.customElements.define('my-awesome-button', MyAwesomeButton); <my-awesome-button class="nice_style">Click me!</my-awesome-button> var myAwesomeButton = document.createElement('my-awesome-button‘); document.body.appendChild(myAwesomeButton); document.querySelector('my-awesome-button‘) .addEventListener('click', function() {...});
Olga Petrova, @tyoushe
Olga Petrova, @tyoushe ExtWebComponents
Olga Petrova, @tyoushe ExtWebComponents 20 import '@sencha/ext-web-components/dist/ext-column.component'; import '@sencha/ext-web-components/dist/ext-grid.component‘;
Olga Petrova, @tyoushe <ext-panel width="100%" height="100%"> <ext-grid multiColumnSort=true onready="basicgrid.onGridReady" title="Stock
Prices"> <ext-column text="Company" flex="1" dataIndex="name"></ext-column> <ext-column text="Price" dataIndex="price" formatter="usMoney"></ext-column> <ext-column text="Last Updated" dataIndex="lastChange"></ext-column> </ext-grid> </ext-panel> import './MyGrid.html'; export default class MyGrid { constructor() { this.store = Ext.create('Ext.data.Store', {...}); } onGridReady = (event) => { this.gridCmp = event.detail.cmp; this.gridCmp.setStore(this.store); } } ExtWebComponents 21 MyGrid.html MyGrid.js
Olga Petrova, @tyoushe Getting Started 22 MyGrid.ts Early adopter access
to ExtWebComponents Trial: https://www.sencha.com/products/extwebcomponents/evaluate/earlyaccess/
Olga Petrova, @tyoushe npm login --registry=https://sencha.myget.org/F/early-adopter/npm/ --scope=@sencha npm install -g
@sencha/ext-web-components-gen ext-web-components-gen app --name MyApp Setup 23 MyGrid.ts
Olga Petrova, @tyoushe Examples 24 ExtWebComponents Kitchensink: https://examples.sencha.com/ExtWebComponents/7.0.0/kitchensink/
Olga Petrova, @tyoushe • 115+ UI Components • Layout System
• Sencha Themer • Sencha Test • Sencha Cmd integration • Ext JS component bridge • Webpack: Build and Bundle ExtReact ExtAngular ExtWebComponents
Olga Petrova, @tyoushe Introduction to ExtReact, ExtAngular, ExtWebComponents Olga Petrova,
@tyoushe
[email protected]