The Webix library provides integration with the React framework.
You can find an example of Webix-React integration on GitHub. To learn more about importing Webix Complex Widgets into a React App, check out this repository.
You can use Webix inside of React App, to add some rich widgets to the existing functionality.
If you plan to use Webix for most UI in the app, please check Webix Jet first. It is a micro-framework for building Webix-based apps. It is native for the library and will help you to manage the development stages in the most natural way.
There are several possible ways to use Webix with React:
Grab the demo from Github if you haven't done this yet. Thus you will get an example of integration usage.
Run npm install
and npm start
after that.
Open http://localhost:3000
to view the demo in the browser.
The page will be reloading while you are editing form fields.
To build the production version, run npm run build
.
It will build the application for production to the build folder. After that your app is ready to be deployed.
You can create a React component with a Webix widget inside like this:
const ui = {
view:"slider"
};
const value = 123;
const SliderView = () => (
<Webix ui={ui} data={value} />
)
The logic is the following:
1. Use the tag < Webix > to define a Webix widget.
2. Specify the necessary view in the ui object and define its config.
Related sample: Simple React component with Webix UI
Instead of using a prebuilt Webix component, there is a possibility to make a custom one. For example, the code for a custom Slider component can look as follows:
class SliderView extends Component {
constructor(props) {
super(props);
this.uiContainer = React.createRef();
}
render() {
return (
<div ref={this.uiContainer}></div>
);
}
componentDidMount(){
webix.ready(() => {
this.ui = webix.ui({
view:"slider",
container:this.uiContainer.current,
});
})
}
componentWillUnmount(){
this.ui.destructor();
this.ui = null;
}
shouldComponentUpdate(){
return false;
}
}
In the above code we have created the SliderView component that contains a Webix slider inside.
The list of the defined methods is:
Related sample: Custom Webix-React component
You can use a Webix widget with Redux without any extra customization required.
For custom components make sure that such a component returns true from shouldComponentUpdate() and provides the componentDidUpdate handler to mutate the state of the Webix widget.
componentDidUpdate(){
if (this.props.data)
this.setWebixData(this.props.data);
if (this.props.select)
this.select(this.props.select);
},
shouldComponentUpdate(){
return true;
}
Related sample: Using Webix with Redux
Back to top