Changing the kendo numeric filter format

后端 未结 8 1620
孤街浪徒
孤街浪徒 2021-02-09 12:16

I am applying custom paging and sorting in the kendo grid. For one of my column I am getting a numeric text box. When I insert the value in numeric text box it is integer, but a

相关标签:
8条回答
  • 2021-02-09 12:41

    On Kendo NumericTextBox, Format is used to format the content of the input when it's not focused. You have tu use Decimals du format the input when it's focused. For example here is a NumericTextbox (asp.net) showing always integer :

    @(Html.Kendo().NumericTextBox<decimal>()
            .Name("Total")
            .Format("n0")
            .Decimals(0)
        )
    

    Hope it will help someone.

    0 讨论(0)
  • 2021-02-09 12:44

    Set the filter column as

    column.filterable = {
        ui: numberFilter,
        cell: {
            template: numberFilter,
        }
    };
    
    function numberFilter(args) {
        var element = args instanceof jQuery ? args : args.element;
        element.kendoNumericTextBox({
            format: "n0"
        });
    }

    0 讨论(0)
  • 2021-02-09 12:54

    For asp.net core grid: columns.Bound(c => c.Expenditure).Format("{0:#,###.00}").Width(75);

    0 讨论(0)
  • 2021-02-09 12:54

    Simply set the column format:

    c.Bound(x => x.ColumnName).Format("{0:#}");
    
    0 讨论(0)
  • 2021-02-09 12:56

    You can set like below

    columns.Bound(x => x.Property).Filterable(x => x.UI("NumericFilter"));
    
    <script type="text/javascript">
    function NumericFilter(control) {
        $(control).kendoNumericTextBox({ "format": "n0", "decimals": 0 });
    
    }
    </script>
    

    Or use extension method

    columns.NumericColumn(x => x.Property);
    
    public static GridBoundColumnBuilder<TModel> NumericColumn<TModel, TValue>(this GridColumnFactory<TModel> Column, Expression<Func<TModel, TValue>> Expression) where TModel : class
    {
        return Column.Bound(Expression).Filterable(x => x.UI("NumericFilter"));
    
    }
    
    0 讨论(0)
  • 2021-02-09 12:59

    I was having the same issue and columns.Bound(x => x.Property).Filterable(x => x.UI("numericFilter")); was not working for me. Piggy backing off of Xavier John's answer I used columns.filterable.cell.template to fix my problem because telerik's documentation states:

    columns.filterable.ui String |Function

    The role data attribute of the widget used in the filter menu or a JavaScript function which initializes that widget.

    This feature is not supported for columns which have their values option set. If filterable.mode is set to 'row', columns.filterable.cell.template should be used to customize the input.

    http://docs.telerik.com/kendo-ui/api/javascript/ui/grid#configuration-columns.filterable.ui

    Here's my code

        @(Html.Kendo().Grid<UnsoldStockBO.USS_STOCK>()
            .Name("searchGrid")
            .Columns(columns =>
            {
                columns.Bound(c => c.CyAbbrev);
                columns.Bound(c => c.UssCrop).Filterable(filter => filter.Cell(c => c.Template("IntegerFilter")));
                columns.Bound(c => c.TtAbbrev);
                columns.Bound(c => c.PtAbbrev);
                columns.Bound(c => c.UssInternalGrade);
                columns.Bound(c => c.SuggestedPrice).Format("{0:c2}").Filterable(filter => filter.Cell(c => c.Template("NumericFilter")));
                columns.Bound(c => c.UssCtPricePerKilo).ClientTemplate("#:kendo.toString(UssCtPricePerKilo, 'c', Culture)#").Filterable(filter => filter.Cell(c => c.Template("NumericFilter")));
                columns.Bound(c => c.UssNetKilos).Format("{0:n}").Filterable(filter => filter.Cell(c => c.Template("NumericFilter")));
                columns.Bound(c => c.UssWriteDownCount).Format("{0:n0}").Filterable(filter => filter.Cell(c => c.Template("IntegerFilter")));
                columns.Command(command =>
                {
                    command.Edit().HtmlAttributes(new { @title = "Quick Edit" });
                    command.Custom("EditStock").HtmlAttributes(new { @title = "Edit" });
                    command.Destroy().HtmlAttributes(new { @title = "Delete" });
                }).HtmlAttributes(new { @nowrap = "nowrap" });
            })
            .Mobile()
            .ToolBar(toolbar => toolbar.Custom().Text("Add Stock").Action("Create", "Stock").Name("AddStock"))
                .Editable(editable => editable.Mode(GridEditMode.InLine).DisplayDeleteConfirmation("This record will be permanently deleted and cannot be recovered. Are you sure?"))
                .Filterable(ftb => ftb.Mode(GridFilterMode.Row))
                .Sortable()
                .Pageable()
                .Events(e => e.DataBound("onDataBound").Cancel("onCancel"))
            .NoRecords("No records found.")
            .Resizable(resize => resize.Columns(true))
            .DataSource(dataSource => dataSource
                .WebApi()
                .ServerOperation(true)
                .PageSize(30)
                            .Events(events => events.Error("error_handler").Sync("sync_handler"))
                        .Model(model =>
                        {
                            model.Id(p => p.UssId);
                            model.Field(c => c.CyAbbrev).Editable(false);
                            model.Field(c => c.UssCrop).Editable(false);
                            model.Field(c => c.TtAbbrev).Editable(false);
                            model.Field(c => c.PtAbbrev).Editable(false);
                            model.Field(c => c.UssInternalGrade).Editable(false);
                            model.Field(c => c.SuggestedPrice).Editable(false);
                        })
                        .Read(read => read.Url(Url.HttpRouteUrl("DefaultApi", new { controller = "webapi", action = "UnsoldStock_Get", userId = ((UnsoldStockBO.PSI_USER)Session["USS_User"]).UUid })))
                                    .Update(update => update.Url(Url.HttpRouteUrl("DefaultApi", new { controller = "webapi", action = "UnsoldStock_Update", userName = ((UnsoldStockBO.PSI_USER)Session["USS_User"]).UUserName })).Type(HttpVerbs.Post))
                                        .Destroy(destroy => destroy.Url(Url.HttpRouteUrl("DefaultApi", new { controller = "webapi", action = "UnsoldStock_Delete", id = "{0}", userName = ((UnsoldStockBO.PSI_USER)Session["USS_User"]).UUserName })).Type(HttpVerbs.Delete))
    
                    )
        )
    
    <script type="text/javascript">
    
        function IntegerFilter(args) {
            args.element.kendoNumericTextBox({ format: "#", decimals: 0, spinners: false });
        }
    
        function NumericFilter(args) {
            args.element.kendoNumericTextBox({ spinners: false });
        }
    
    </script>
    
    0 讨论(0)
提交回复
热议问题