12/08/2018, 16:53

ReactJS - Crop ảnh với thư việt React Cropper

Chào các bạn, trong bài viết này mình sẽ giới thiệu thư viện React Cropper - một thư viện dùng để cắt ảnh trong ReactJS. Xem thử Demo Giới thiệu React Cropper là thư viện được viết bởi Fong Kuanghuei . Thống kê tại thời điểm mình viết bài, số lượng downloads last day là 2114, downloads ...

Chào các bạn, trong bài viết này mình sẽ giới thiệu thư viện React Cropper - một thư viện dùng để cắt ảnh trong ReactJS. Xem thử Demo

Giới thiệu

React Cropper là thư viện được viết bởi Fong Kuanghuei. Thống kê tại thời điểm mình viết bài, số lượng downloads last day là 2114, downloads last week là 9092 lượt và 35255 lượt downloads last month, như vậy có thể thấy thư viện này được khá nhiều người sử dụng. (Theo mình kiểm tra một số thư viện crop anh khác thì React Cropper là thư viện có số người dùng nhiều nhất).

Cài đặt

Cài đặt bằng cú pháp sau:

npm install --save react-cropper

Cách dùng

Dưới đây là đoạn code mẫu cách dùng

import React, {Component} from 'react';
import Cropper from 'react-cropper'; //Import Cropper Component
import 'cropperjs/dist/cropper.css';  //Import file style
 
class Demo extends Component {
  _crop(){
    // image in dataUrl
    console.log(this.cropper.getCroppedCanvas().toDataURL());
  }
 
  render() {
    return (
      <Cropper
        ref={cropper => { this.cropper = cropper; }}
        src="http://fengyuanchen.github.io/cropper/img/picture.jpg"
        style={{height: 400, awidth: '100%'}}
        // Cropper.js options
        aspectRatio={16 / 9}
        guides={false}
        crop={this._crop.bind(this)} />
    );
  }
}

Thiết lập cơ bản

Một số thiết lập cơ bản:

src: //Link ảnh crop (default null)
style: //Internal style
aspectRatio: //Tỉ lệ awidth/height
dragMode: //thiết lập cho drag crop section (default crop)
guides: //Hiện thị những dòng kẻ chấm dưới box crop (default true)
zoomable: //thiết lập zoom ảnh (default true)
scaleble: //Thiết lập scale ảnh (default true)
movable: //Thiết lập move ảnh (default true)
...

Xem chi tiết tất cả các options tại đây Docs

Kết luận

Rất dễ phải không nào, nếu dự án của bạn cần tính năng crop image, hãy thử package này nhé.

0