Features

Introduction

Introduction

The FlexSheet control extends the FlexGrid control and provides an Excel-like functionality.

Features

Introduction

The FlexSheet control extends the FlexGrid control and provides an Excel-like functionality.
FlexSheet supports all the FlexGrid's features, and focuses on the key features from Excel not included in FlexGrid.

Note:FlexSheet requires the JSZip library for loading and saving xlsx file, you should add jszip.js via CDN or include the script file in the project.

FlexSheet provides following Excel-like features:

Multiple Sheets
Include multiple separated sheets in a single worksheet.
Formulas
Calculation engine includes built-in formula support, complete with nearly 100 formulas and auto-completion. Our formula operations were built to align with Microsoft Excel, including operations for aggregation, mathematics, logic and text.
Cell Style
Cell-styling support includes format, font, horizontal alignment, fore color, fill color and more.
Merge Cells
User can merge any cells, in contrast with FlexGrid, which only supports content-driven cell merging.
Undo/Redo
Undo/redo mutiple operations include edit cell, insert/remove rows/columns, apply cell style, merge cells, resize rows/columns, drag and drop rows/columns and more.
Drag & Drop
Drag and drop rows/columns for moving and copying.
Select whole column
Select the whole column by clicking the column header.
Allow Auto Fill
Auto fill cells with data that follows a pattern by dragging the bottom right corner of the cell.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;

namespace FlexSheetExplorer.Controllers
{
    public partial class FlexSheetController : Controller
    {
        public ActionResult Intro()
        {
            return View();
        }
    }
}
<div>
    <div class="copy">
        <h3>@Html.Raw(Resources.FlexSheet.Intro_Text4)</h3>

        <p>@Html.Raw(Resources.FlexSheet.Intro_Text0)</p>

        <div class="collapsed-content collapse">
            <p>@Html.Raw(Resources.FlexSheet.Intro_Text1)</p>

            <dl class="dl-horizontal">
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text5)</dt>
                <dd>@Html.Raw(Resources.FlexSheet.Intro_Text6)</dd>
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text7)</dt>
                <dd>
                    @Html.Raw(Resources.FlexSheet.Intro_Text8)
                </dd>
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text9)</dt>
                <dd>@Html.Raw(Resources.FlexSheet.Intro_Text10)</dd>
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text11)</dt>
                <dd>@Html.Raw(Resources.FlexSheet.Intro_Text12)</dd>
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text13)</dt>
                <dd>
                    @Html.Raw(Resources.FlexSheet.Intro_Text14)
                </dd>
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text15)</dt>
                <dd>@Html.Raw(Resources.FlexSheet.Intro_Text16)</dd>
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text17)</dt>
                <dd>@Html.Raw(Resources.FlexSheet.Intro_Text18)</dd>
                <dt>@Html.Raw(Resources.FlexSheet.Intro_Text20)</dt>
                <dd>@Html.Raw(Resources.FlexSheet.Intro_Text21)</dd>
            </dl>
        </div>
        <p>
            <button type="button"
                    data-toggle="collapse"
                    data-target=".collapsed-content, .btn.btn-default.btn-xs.collapse"
                    class="btn btn-default btn-xs collapse in">
                @Html.Raw(Resources.FlexSheet.Intro_Text19)
            </button>
        </p>

    </div>
    <div>
        @(Html.C1().FlexSheet().CssClass("flexSheet")
        .AddUnboundSheet("Sheet1", 25, 12)
        .AddUnboundSheet("Sheet2", 25, 12)
        .AllowAutoFill(true)
        )
    </div>
</div>
@section Summary{
<p>@Html.Raw(Resources.FlexSheet.Intro_Text3)</p>

}