В своем вопросе вы запросили решение AngularJS, но вместо этого в своем коде вы продемонстрировали пример Angular. Я хочу убедиться, что вы понимаете, что они очень отличаются друг от друга .
Следующий код взят из проекта моей шахматной игры с использованием AngularJS :
Шаблон HTML
<main class="container">
<div>
<button class="btn btn-primary center" ng-click="startGame()">Start Chess</button>
</div>
<div class="game-board center">
<div class="game-board-row" ng-repeat="row in rows">
<div class="game-board-grid" ng-repeat="col in cols" data-x="{{ col }}" data-y="{{ row }}" ng-click="click(this);">
<div class="piece" data-text-color="{{ game.data.grids[row][col].value.group }}" data-bg-color="game.data.grids[row][col].occupied">{{ game.data.grids[row][col].value.text }}</div>
</div>
</div>
</div>
</main>
JavaScript (AngularJS)
<script type="text/javascript">
let app = angular.module('game', []);
app.run(($rootScope) => {
$rootScope.rows = ['0', '1', '2', '3'];
$rootScope.cols = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12'];
});
</script>
Если вместо используется Angular , измените код на следующий стиль:
HTML-шаблон
<main class="container">
<div>
<button class="btn btn-primary center" (click)="startGame()">Start Chess</button>
</div>
<div class="game-board center">
<div class="game-board-row" *ngFor="row in rows">
<div class="game-board-grid" *ngFor="col in cols" [data-x]="col" [data-y]="row" (click)="click(this);">
<div class="piece" [data-text-color]="game.data.grids[row][col].value.group" [data-bg-color]="game.data.grids[row][col].occupied">{{ game.data.grids[row][col].value.text }}</div>
</div>
</div>
</div>
</main>
JavaScript (угловой)
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-game',
templateUrl: './game.component.html',
styleUrls: ['./game.component.scss']
})
export class GameComponent implements OnInit {
rows = ['0', '1', '2', '3'];
cols = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12'];
constructor() { }
ngOnInit() {
}
}
Если вы хотите выбрать эти сетки с помощью CSS , вам понадобится селектор атрибутов ! Например:
[data-x="1"][data-y="2"] {
/* This selects the grid located at (1, 2) */
}