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],
            }]
        });
    }
}