Ext.js-접근성
일반적으로 접근성은 가용성을 의미하고 콘텐츠는 콘텐츠를 사용할 수 있음을 의미합니다.
소프트웨어 측면에서 응용 프로그램에 액세스 할 수 있다는 것은 응용 프로그램을 모든 사람이 사용할 수 있음을 의미합니다. 여기에서 모두는 장애인, 시각 장애인 또는 화면 판독기를 사용하여 컴퓨터를 사용하는 사용자 또는 마우스 대신 키보드를 사용하여 탐색하는 것을 선호하는 사용자를 의미합니다. 마우스를 사용하는 대신 키보드로 탐색합니다.
액세스 가능한 애플리케이션을 ARIA (Accessible Rich Internet Applications)라고합니다.
Ext JS의 접근성
Ext JS는 모든 키보드 탐색과 함께 작동해야한다는 점을 염두에두고 설계되었습니다. 기본 제공 탭 인덱싱 및 포커스 기능이 있으며 기본적으로 항상 켜져 있으므로이 기능을 활성화하기 위해 속성을 추가 할 필요가 없습니다.
이 기능을 사용하면 모든 키보드 사용 구성 요소가 탭으로 이동할 때 사용자와 상호 작용할 수 있습니다. 예를 들어, 마우스 대신 다음 구성 요소로 이동하기 위해 탭을 사용할 수 있습니다. 같은 방식으로 뒤로 이동하려면 Shift + Tab을 사용하고 클릭하려면 키보드의 Enter 키를 사용할 수 있습니다.
포커스 스타일링 및 탭
탭에 키 입력을 사용할 때 Extjs에 포커스가 내장되어 있습니다.
다음 예제는 탭으로 포커스가 변경 될 때 스타일을 변경하는 방법을 보여줍니다.
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-crisp/resources/theme-crisp-all.css"
rel = "stylesheet" />
<script type = "text/javascript"
src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
<script type = "text/javascript">
Ext.onReady(function(){
Ext.create('Ext.Button', {
renderTo: Ext.getElementById('button1'),
text: 'Button1',
listeners: {
click: function() {
Ext.MessageBox.alert('Alert box', 'Button 1 is clicked');
}
}
});
Ext.create('Ext.Button', {
renderTo: Ext.getElementById('button2'),
text: 'Button2',
listeners: {
click: function() {
Ext.MessageBox.alert('Alert box', 'Button 2 is clicked');
}
}
});
Ext.create('Ext.Button', {
renderTo: Ext.getElementById('button3'),
text: 'Button3',
listeners: {
click: function() {
Ext.MessageBox.alert('Alert box', 'Button 3 is clicked');
}
}
});
});
</script>
</head>
<body> <p>Please click the button to see event listener:</p>
<span id = "button3"/>
<span id = "button2"/>
<span id = "button1"/>
</body>
</html>
효과를 확인하려면 탭을 사용하여 다음 버튼에서 이동하고 shft + tab을 사용하여 뒤로 초점을 맞 춥니 다. Enter를 사용하여 포커스가있는 버튼의 관련 경고가 어떻게 표시되는지 확인합니다.
ARIA 테마
ExtJS는 시각 장애인을위한 테마 아리아를 제공합니다.
다음 예는 시각 장애인이 쉽게 접근 할 수있는 아리아 테마를 보여줍니다.
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-aria/resources/theme-aria-all.css"
rel = "stylesheet" />
<script type = "text/javascript"
src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
<script type = "text/javascript">
Ext.require([
'Ext.grid.*',
'Ext.data.*'
]);
// Creation of data model
Ext.define('StudentDataModel', {
extend: 'Ext.data.Model',
fields: [
{name: 'name', mapping : 'name'},
{name: 'age', mapping : 'age'},
{name: 'marks', mapping : 'marks'}
]
});
Ext.onReady(function() {
// Store data
var myData = [
{ name : "Asha", age : "16", marks : "90" },
{ name : "Vinit", age : "18", marks : "95" },
{ name : "Anand", age : "20", marks : "68" },
{ name : "Niharika", age : "21", marks : "86" },
{ name : "Manali", age : "22", marks : "57" }
];
// Creation of first grid store
var firstGridStore = Ext.create('Ext.data.Store', {
model: 'StudentDataModel',
data: myData
});
// Creation of first grid
var firstGrid = Ext.create('Ext.grid.Panel', {
store : firstGridStore,
columns :
[{
header: "Student Name",
dataIndex: 'name',
id : 'name',
flex: 1,
sortable: true
},{
header: "Age",
dataIndex: 'age',
flex: .5,
sortable: true
},{
header: "Marks",
dataIndex: 'marks',
flex: .5,
sortable: true
}],
stripeRows : true,
title : 'First Grid',
margins : '0 2 0 0'
});
// Creation of a panel to show both the grids.
var displayPanel = Ext.create('Ext.Panel', {
width : 600,
height : 200,
layout : {
type: 'hbox',
align: 'stretch',
padding: 5
},
renderTo : 'panel',
defaults : { flex : 1 },
items : [
firstGrid
]
});
});
</script>
</head>
<body>
<div id = "panel" > </div>
</body>
</html>
위의 프로그램은 다음과 같은 결과를 생성합니다. 그리드에서 포커스를 이동하기 위해 탭과 마우스 위 / 아래 키를 사용할 수 있으며 테마는 기본적으로 시각 장애인을위한 것입니다.