{"id":1570,"date":"2022-05-09T13:14:06","date_gmt":"2022-05-09T07:44:06","guid":{"rendered":"https:\/\/blog.binarybits.net\/?p=1570"},"modified":"2022-05-09T13:15:52","modified_gmt":"2022-05-09T07:45:52","slug":"binding-buttons-in-spfx","status":"publish","type":"post","link":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/","title":{"rendered":"Binding buttons in SPFx"},"content":{"rendered":"\n

When writing a react based SPFx application one has to make a note that ES6 React.Component doesn’t auto bind methods to itself.<\/p>\n\n\n\n

Hence it’s required to manually bind and the following are two ways to do it.<\/p>\n\n\n\n

Method 1<\/h2>\n\n\n\n

onClick={this.addButtonClicked.bind(this)}<\/p><\/blockquote>\n\n\n\n

import * as React from 'react';\n\nimport { Stack, IStackProps, IStackStyles } from 'office-ui-fabric-react\/lib\/Stack';\nimport { ActionButton } from 'office-ui-fabric-react\/lib\/Button';\nimport { IIconProps } from 'office-ui-fabric-react\/';\n\nimport { ITestComponentState } from '.\/ITestComponentState';\nimport { ITestComponentProps } from '.\/ITestComponentProps';\n\n\/\/Stack related styles\nconst outerStackTokens = {\n    childrenGap: 50\n};\nconst addFriendIcon: IIconProps = { iconName: 'Add' };\n\nlet outerStackStyles: Partial<IStackStyles> = {};\nlet innerStackColumnProps: Partial<IStackProps> = {};\n\nexport default class TestComponent extends React.Component<ITestComponentProps, ITestComponentState> {\n    constructor(props: ITestComponentProps) {\n        super(props);\n        this.state = {\n            items: []\n        };\n    }\n  \n    public render(): React.ReactElement<{}> {\n        return (\n            <div>\n                <Stack horizontal tokens={outerStackTokens} styles={outerStackStyles}>\n                    <Stack verticalAlign="start" {...innerStackColumnProps}>\n                        <Stack.Item align="start" >\n                            <ActionButton iconProps={addFriendIcon} onClick={this.addButtonClicked.bind(this)} allowDisabledFocus disabled={this.state.sortItems.length >= 10 ? true : false} >Add Item<\/ActionButton>\n                        <\/Stack.Item>\n                    <\/Stack>\n                <\/Stack>\n            <\/div>\n        );\n    }\n\n    private addButtonClicked(event?: React.MouseEvent<HTMLButtonElement>) {\n        let itemsOnAdd = this.state.items;\n        let itemTitle = "Item " + (this.state.items.length + 1);\n        itemsOnAdd.push({ title: itemTitle });\n        this.setState({ items: itemsOnAdd });\n    }\n}<\/pre><\/div>\n\n\n\n

Method 2<\/h2>\n\n\n\n

this.addButtonClicked = this.addButtonClicked.bind(this);<\/p><\/blockquote>\n\n\n\n

import * as React from 'react';\n\nimport { Stack, IStackProps, IStackStyles } from 'office-ui-fabric-react\/lib\/Stack';\nimport { ActionButton } from 'office-ui-fabric-react\/lib\/Button';\nimport { IIconProps } from 'office-ui-fabric-react\/';\n\nimport { ITestComponentState } from '.\/ITestComponentState';\nimport { ITestComponentProps } from '.\/ITestComponentProps';\n\n\/\/Stack related styles\nconst outerStackTokens = {\n    childrenGap: 50\n};\nconst addFriendIcon: IIconProps = { iconName: 'Add' };\n\nlet outerStackStyles: Partial<IStackStyles> = {};\nlet innerStackColumnProps: Partial<IStackProps> = {};\n\nexport default class TestComponent extends React.Component<ITestComponentProps, ITestComponentState> {\n    constructor(props: ITestComponentProps) {\n        super(props);\n        this.state = {\n            items: []\n        };\n        this.addButtonClicked = this.addButtonClicked.bind(this);\n    }\n  \n    public render(): React.ReactElement<{}> {\n        return (\n            <div>\n                <Stack horizontal tokens={outerStackTokens} styles={outerStackStyles}>\n                    <Stack verticalAlign="start" {...innerStackColumnProps}>\n                        <Stack.Item align="start" >\n                            <ActionButton iconProps={addFriendIcon} onClick={this.addButtonClicked} allowDisabledFocus disabled={this.state.sortItems.length >= 10 ? true : false} >Add Item<\/ActionButton>\n                        <\/Stack.Item>\n                    <\/Stack>\n                <\/Stack>\n            <\/div>\n        );\n    }\n\n    private addButtonClicked(event?: React.MouseEvent<HTMLButtonElement>) {\n        let itemsOnAdd = this.state.items;\n        let itemTitle = "Item " + (this.state.items.length + 1);\n        itemsOnAdd.push({ title: itemTitle });\n        this.setState({ items: itemsOnAdd });\n    }\n}<\/pre><\/div>\n","protected":false},"excerpt":{"rendered":"

When writing a react based SPFx application one has to make a note that ES6 React.Component doesn’t auto bind methods to itself. Hence it’s required to manually bind and the following are two ways to do it. Method 1 onClick={this.addButtonClicked.bind(this)} Method 2 this.addButtonClicked = this.addButtonClicked.bind(this);<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"inline_featured_image":false,"footnotes":""},"categories":[305,62],"tags":[],"yoast_head":"\nBinding buttons in SPFx : Binary Bits<\/title>\n<meta name=\"description\" content=\"Two methods to bind buttons in SPFx\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/\" \/>\n<meta property=\"og:locale\" content=\"en_GB\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Binding buttons in SPFx : Binary Bits\" \/>\n<meta property=\"og:description\" content=\"Two methods to bind buttons in SPFx\" \/>\n<meta property=\"og:url\" content=\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/\" \/>\n<meta property=\"og:site_name\" content=\"Binary Bits\" \/>\n<meta property=\"article:published_time\" content=\"2022-05-09T07:44:06+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-05-09T07:45:52+00:00\" \/>\n<meta name=\"author\" content=\"Kannan\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@Kannan_B\" \/>\n<meta name=\"twitter:site\" content=\"@Kannan_B\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Kannan\" \/>\n\t<meta name=\"twitter:label2\" content=\"Estimated reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/\"},\"author\":{\"name\":\"Kannan\",\"@id\":\"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855\"},\"headline\":\"Binding buttons in SPFx\",\"datePublished\":\"2022-05-09T07:44:06+00:00\",\"dateModified\":\"2022-05-09T07:45:52+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/\"},\"wordCount\":55,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855\"},\"articleSection\":[\"React\",\"SharePoint\"],\"inLanguage\":\"en-GB\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/\",\"url\":\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/\",\"name\":\"Binding buttons in SPFx : Binary Bits\",\"isPartOf\":{\"@id\":\"https:\/\/blog.binarybits.net\/#website\"},\"datePublished\":\"2022-05-09T07:44:06+00:00\",\"dateModified\":\"2022-05-09T07:45:52+00:00\",\"description\":\"Two methods to bind buttons in SPFx\",\"breadcrumb\":{\"@id\":\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#breadcrumb\"},\"inLanguage\":\"en-GB\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/blog.binarybits.net\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Binding buttons in SPFx\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/blog.binarybits.net\/#website\",\"url\":\"https:\/\/blog.binarybits.net\/\",\"name\":\"Binary Bits\",\"description\":\"Bits & Pieces - A blog by Kannan Balasubramanian\",\"publisher\":{\"@id\":\"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/blog.binarybits.net\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"en-GB\"},{\"@type\":[\"Person\",\"Organization\"],\"@id\":\"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855\",\"name\":\"Kannan\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-GB\",\"@id\":\"https:\/\/blog.binarybits.net\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/blog.binarybits.net\/wp-content\/uploads\/2017\/04\/12976869_10207528235497646_1307827709790943986_o.jpg\",\"contentUrl\":\"https:\/\/blog.binarybits.net\/wp-content\/uploads\/2017\/04\/12976869_10207528235497646_1307827709790943986_o.jpg\",\"width\":1270,\"height\":1270,\"caption\":\"Kannan\"},\"logo\":{\"@id\":\"https:\/\/blog.binarybits.net\/#\/schema\/person\/image\/\"}}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Binding buttons in SPFx : Binary Bits","description":"Two methods to bind buttons in SPFx","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/","og_locale":"en_GB","og_type":"article","og_title":"Binding buttons in SPFx : Binary Bits","og_description":"Two methods to bind buttons in SPFx","og_url":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/","og_site_name":"Binary Bits","article_published_time":"2022-05-09T07:44:06+00:00","article_modified_time":"2022-05-09T07:45:52+00:00","author":"Kannan","twitter_card":"summary_large_image","twitter_creator":"@Kannan_B","twitter_site":"@Kannan_B","twitter_misc":{"Written by":"Kannan","Estimated reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#article","isPartOf":{"@id":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/"},"author":{"name":"Kannan","@id":"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855"},"headline":"Binding buttons in SPFx","datePublished":"2022-05-09T07:44:06+00:00","dateModified":"2022-05-09T07:45:52+00:00","mainEntityOfPage":{"@id":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/"},"wordCount":55,"commentCount":0,"publisher":{"@id":"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855"},"articleSection":["React","SharePoint"],"inLanguage":"en-GB","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/","url":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/","name":"Binding buttons in SPFx : Binary Bits","isPartOf":{"@id":"https:\/\/blog.binarybits.net\/#website"},"datePublished":"2022-05-09T07:44:06+00:00","dateModified":"2022-05-09T07:45:52+00:00","description":"Two methods to bind buttons in SPFx","breadcrumb":{"@id":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#breadcrumb"},"inLanguage":"en-GB","potentialAction":[{"@type":"ReadAction","target":["https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/blog.binarybits.net\/binding-buttons-in-spfx\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/blog.binarybits.net\/"},{"@type":"ListItem","position":2,"name":"Binding buttons in SPFx"}]},{"@type":"WebSite","@id":"https:\/\/blog.binarybits.net\/#website","url":"https:\/\/blog.binarybits.net\/","name":"Binary Bits","description":"Bits & Pieces - A blog by Kannan Balasubramanian","publisher":{"@id":"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/blog.binarybits.net\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"en-GB"},{"@type":["Person","Organization"],"@id":"https:\/\/blog.binarybits.net\/#\/schema\/person\/dda0e26212583a95f286cf67604fd855","name":"Kannan","image":{"@type":"ImageObject","inLanguage":"en-GB","@id":"https:\/\/blog.binarybits.net\/#\/schema\/person\/image\/","url":"https:\/\/blog.binarybits.net\/wp-content\/uploads\/2017\/04\/12976869_10207528235497646_1307827709790943986_o.jpg","contentUrl":"https:\/\/blog.binarybits.net\/wp-content\/uploads\/2017\/04\/12976869_10207528235497646_1307827709790943986_o.jpg","width":1270,"height":1270,"caption":"Kannan"},"logo":{"@id":"https:\/\/blog.binarybits.net\/#\/schema\/person\/image\/"}}]}},"_links":{"self":[{"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/posts\/1570"}],"collection":[{"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/comments?post=1570"}],"version-history":[{"count":3,"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/posts\/1570\/revisions"}],"predecessor-version":[{"id":1575,"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/posts\/1570\/revisions\/1575"}],"wp:attachment":[{"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/media?parent=1570"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/categories?post=1570"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.binarybits.net\/wp-json\/wp\/v2\/tags?post=1570"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}