Navigation Methods
Programmatically navigate through spreadsheet cells and control active cell positioning with built-in navigation methods.
Documentation
Methods
| Method | Description |
|---|---|
goto(y, x?) |
Move to specific cell coordinates.goto(row: number, col?: number) |
pageUp() |
Scroll up by one page.pageUp() : void |
pageDown() |
Scroll down by one page.pageDown() : void |
left() |
Move one cell left.left() : void |
up() |
Move one cell up.up() : void |
right() |
Move one cell right.right() : void |
down() |
Move one cell down.down() : void |
last() |
Move to last cell with data.last() : void |
first() |
Move to first cell (A1).first() : void |
Examples
Basic Navigation
<html>
<script src="https://jspreadsheet.com/v12/jspreadsheet.js"></script>
<link rel="stylesheet" href="https://jspreadsheet.com/v12/jspreadsheet.css" type="text/css" />
<script src="https://jsuites.net/v6/jsuites.js"></script>
<link rel="stylesheet" href="https://jsuites.net/v6/jsuites.css" type="text/css" />
<div id="spreadsheet"></div>
<p class="jss_object">
<input type="button" id="btn1" value="Left" />
<input type="button" id="btn2" value="Up" />
<input type="button" id="btn3" value="Right" />
<input type="button" id="btn4" value="Down" />
<input type="button" id="btn5" value="First" />
<input type="button" id="btn6" value="Last" />
</p>
<script>
// Set your JSS license key (The following key only works for one day)
jspreadsheet.setLicense('NTg2YTA4YzBkZjAzNjlmM2VhNjIyYWRlNThlZDlkZGNkZTdiOTBhOTU2MDMyMzc1ZGEyYTA0NDhjYjNmNTNkODdkMDJmYjZhZDIxMzYwMGJiNTQxMjRhYzg5YTBkNGJhZTJkYmJiM2I3ZTRkMjgwYTRjNmMwZDc5NGRlYTM1OTcsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpZME1EWTJPRFUwTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0p6ZEdGamEySnNhWFI2TG1sdklpd2lkMlZpWTI5dWRHRnBibVZ5TG1sdklpd2liRzlqWVd4b2IzTjBJbDBzSW5Cc1lXNGlPaUl6TkNJc0luTmpiM0JsSWpwYkluWTNJaXdpZGpnaUxDSjJPU0lzSW5ZeE1DSXNJbll4TVNJc0luWXhNaUlzSW1Ob1lYSjBjeUlzSW1admNtMXpJaXdpWm05eWJYVnNZU0lzSW5CaGNuTmxjaUlzSW5KbGJtUmxjaUlzSW1OdmJXMWxiblJ6SWl3aWFXMXdiM0owWlhJaUxDSmlZWElpTENKMllXeHBaR0YwYVc5dWN5SXNJbk5sWVhKamFDSXNJbkJ5YVc1MElpd2ljMmhsWlhSeklpd2lZMnhwWlc1MElpd2ljMlZ5ZG1WeUlpd2ljMmhoY0dWeklpd2labTl5YldGMElsMHNJbVJsYlc4aU9uUnlkV1Y5');
// Create a new spreadsheet
let spreadsheet = jspreadsheet(document.getElementById('spreadsheet'), {
worksheets: [{
data: [
['Mazda', 2001, 2000],
['Peugeot', 2010, 5000],
['Honda', 2020, 3000],
['Fiat', 2015, 4000],
],
minDimensions: [6, 6],
}]
});
document.getElementById("btn1").onclick = () => spreadsheet[0].left();
document.getElementById("btn2").onclick = () => spreadsheet[0].up();
document.getElementById("btn3").onclick = () => spreadsheet[0].right();
document.getElementById("btn4").onclick = () => spreadsheet[0].down();
document.getElementById("btn5").onclick = () => spreadsheet[0].first();
document.getElementById("btn6").onclick = () => spreadsheet[0].last();
</script>
</html>
import React, {useRef} from "react";
import {Spreadsheet, Worksheet, jspreadsheet} from "@jspreadsheet/react";
import "jsuites/dist/jsuites.css";
import "jspreadsheet/dist/jspreadsheet.css";
// Set your JSS license key (The following key only works for one day)
jspreadsheet.setLicense('NTg2YTA4YzBkZjAzNjlmM2VhNjIyYWRlNThlZDlkZGNkZTdiOTBhOTU2MDMyMzc1ZGEyYTA0NDhjYjNmNTNkODdkMDJmYjZhZDIxMzYwMGJiNTQxMjRhYzg5YTBkNGJhZTJkYmJiM2I3ZTRkMjgwYTRjNmMwZDc5NGRlYTM1OTcsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpZME1EWTJPRFUwTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0p6ZEdGamEySnNhWFI2TG1sdklpd2lkMlZpWTI5dWRHRnBibVZ5TG1sdklpd2liRzlqWVd4b2IzTjBJbDBzSW5Cc1lXNGlPaUl6TkNJc0luTmpiM0JsSWpwYkluWTNJaXdpZGpnaUxDSjJPU0lzSW5ZeE1DSXNJbll4TVNJc0luWXhNaUlzSW1Ob1lYSjBjeUlzSW1admNtMXpJaXdpWm05eWJYVnNZU0lzSW5CaGNuTmxjaUlzSW5KbGJtUmxjaUlzSW1OdmJXMWxiblJ6SWl3aWFXMXdiM0owWlhJaUxDSmlZWElpTENKMllXeHBaR0YwYVc5dWN5SXNJbk5sWVhKamFDSXNJbkJ5YVc1MElpd2ljMmhsWlhSeklpd2lZMnhwWlc1MElpd2ljMlZ5ZG1WeUlpd2ljMmhoY0dWeklpd2labTl5YldGMElsMHNJbVJsYlc4aU9uUnlkV1Y5');
export default function App() {
// Spreadsheet array of worksheets
const spreadsheet = useRef();
// Data
const data = [
['Mazda', 2001, 2000],
['Peugeot', 2010, 5000],
['Honda', 2020, 3000],
['Fiat', 2015, 4000],
];
// Render component
return (
<>
<Spreadsheet ref={spreadsheet}>
<Worksheet data={data} minDimensions={[6, 6]} />
</Spreadsheet>
<input type="button" value="Left" onClick={() => spreadsheet.current[0].left()} />
<input type="button" value="Up" onClick={() => spreadsheet.current[0].up()} />
<input type="button" value="Right" onClick={() => spreadsheet.current[0].right()} />
<input type="button" value="Down" onClick={() => spreadsheet.current[0].down()} />
<input type="button" value="First" onClick={() => spreadsheet.current[0].first()} />
<input type="button" value="Last" onClick={() => spreadsheet.current[0].last()} />
</>
);
}
<template>
<Spreadsheet ref="spreadsheet">
<Worksheet :data="data" :minDimensions="[6, 6]" />
</Spreadsheet>
<input type="button" value="Left" @click="$refs.spreadsheet[0].left()" />
<input type="button" value="Up" @click="$refs.spreadsheet[0].up()" />
<input type="button" value="Right" @click="$refs.spreadsheet[0].right()" />
<input type="button" value="Down" @click="$refs.spreadsheet[0].down()" />
<input type="button" value="First" @click="$refs.spreadsheet[0].first()" />
<input type="button" value="Last" @click="$refs.spreadsheet[0].last()" />
</template>
<script>
import { Spreadsheet, Worksheet, jspreadsheet } from "@jspreadsheet/vue";
import "jsuites/dist/jsuites.css";
import "jspreadsheet/dist/jspreadsheet.css";
// Set your JSS license key (The following key only works for one day)
jspreadsheet.setLicense('NTg2YTA4YzBkZjAzNjlmM2VhNjIyYWRlNThlZDlkZGNkZTdiOTBhOTU2MDMyMzc1ZGEyYTA0NDhjYjNmNTNkODdkMDJmYjZhZDIxMzYwMGJiNTQxMjRhYzg5YTBkNGJhZTJkYmJiM2I3ZTRkMjgwYTRjNmMwZDc5NGRlYTM1OTcsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpZME1EWTJPRFUwTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0p6ZEdGamEySnNhWFI2TG1sdklpd2lkMlZpWTI5dWRHRnBibVZ5TG1sdklpd2liRzlqWVd4b2IzTjBJbDBzSW5Cc1lXNGlPaUl6TkNJc0luTmpiM0JsSWpwYkluWTNJaXdpZGpnaUxDSjJPU0lzSW5ZeE1DSXNJbll4TVNJc0luWXhNaUlzSW1Ob1lYSjBjeUlzSW1admNtMXpJaXdpWm05eWJYVnNZU0lzSW5CaGNuTmxjaUlzSW5KbGJtUmxjaUlzSW1OdmJXMWxiblJ6SWl3aWFXMXdiM0owWlhJaUxDSmlZWElpTENKMllXeHBaR0YwYVc5dWN5SXNJbk5sWVhKamFDSXNJbkJ5YVc1MElpd2ljMmhsWlhSeklpd2lZMnhwWlc1MElpd2ljMlZ5ZG1WeUlpd2ljMmhoY0dWeklpd2labTl5YldGMElsMHNJbVJsYlc4aU9uUnlkV1Y5');
export default {
components: {
Spreadsheet,
Worksheet,
},
data() {
return {
data: [
['Mazda', 2001, 2000],
['Peugeot', 2010, 5000],
['Honda', 2020, 3000],
['Fiat', 2015, 4000],
],
};
}
}
</script>
import { Component, ViewChild, ElementRef, AfterViewInit } from "@angular/core";
import jspreadsheet from "jspreadsheet";
import "jspreadsheet/dist/jspreadsheet.css";
import "jsuites/dist/jsuites.css";
// Set your JSS license key (The following key only works for one day)
jspreadsheet.setLicense('NTg2YTA4YzBkZjAzNjlmM2VhNjIyYWRlNThlZDlkZGNkZTdiOTBhOTU2MDMyMzc1ZGEyYTA0NDhjYjNmNTNkODdkMDJmYjZhZDIxMzYwMGJiNTQxMjRhYzg5YTBkNGJhZTJkYmJiM2I3ZTRkMjgwYTRjNmMwZDc5NGRlYTM1OTcsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpZME1EWTJPRFUwTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0p6ZEdGamEySnNhWFI2TG1sdklpd2lkMlZpWTI5dWRHRnBibVZ5TG1sdklpd2liRzlqWVd4b2IzTjBJbDBzSW5Cc1lXNGlPaUl6TkNJc0luTmpiM0JsSWpwYkluWTNJaXdpZGpnaUxDSjJPU0lzSW5ZeE1DSXNJbll4TVNJc0luWXhNaUlzSW1Ob1lYSjBjeUlzSW1admNtMXpJaXdpWm05eWJYVnNZU0lzSW5CaGNuTmxjaUlzSW5KbGJtUmxjaUlzSW1OdmJXMWxiblJ6SWl3aWFXMXdiM0owWlhJaUxDSmlZWElpTENKMllXeHBaR0YwYVc5dWN5SXNJbk5sWVhKamFDSXNJbkJ5YVc1MElpd2ljMmhsWlhSeklpd2lZMnhwWlc1MElpd2ljMlZ5ZG1WeUlpd2ljMmhoY0dWeklpd2labTl5YldGMElsMHNJbVJsYlc4aU9uUnlkV1Y5');
@Component({
standalone: true,
selector: "app-root",
template: `
<div #spreadsheet></div>
<input type="button" value="Left" (click)="worksheets[0].left()" />
<input type="button" value="Up" (click)="worksheets[0].up()" />
<input type="button" value="Right" (click)="worksheets[0].right()" />
<input type="button" value="Down" (click)="worksheets[0].down()" />
<input type="button" value="First" (click)="worksheets[0].first()" />
<input type="button" value="Last" (click)="worksheets[0].last()" />
`
})
export class AppComponent implements AfterViewInit {
@ViewChild("spreadsheet") spreadsheet: ElementRef;
// Worksheets
worksheets: jspreadsheet.worksheetInstance[];
// Create a new data grid
ngAfterViewInit() {
// Create spreadsheet
this.worksheets = jspreadsheet(this.spreadsheet.nativeElement, {
worksheets: [{
data: [
['Mazda', 2001, 2000],
['Peugeot', 2010, 5000],
['Honda', 2020, 3000],
['Fiat', 2015, 4000],
],
minDimensions: [6, 6],
}]
});
}
}