欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react搭建在線編輯html的站點通過引入grapes實現(xiàn)在線拖拉拽編輯html

 更新時間:2023年08月08日 10:29:18   作者:yma16  
Grapes插件是一種用于Web開發(fā)的開源工具,可以幫助用戶快速創(chuàng)建動態(tài)和交互式的網(wǎng)頁元素,它還支持多語言和多瀏覽器,適合開發(fā)響應式網(wǎng)頁和移動應用程序,這篇文章主要介紹了react搭建在線編輯html的站點通過引入grapes實現(xiàn)在線拖拉拽編輯html,需要的朋友可以參考下

?前言

本文分享關于react搭建在線編輯html的站點。

react 發(fā)展歷史

React是由Facebook開發(fā)的一種JavaScript庫,用于構建用戶界面。React最初發(fā)布于2013年,并在2015年開源。以下是React框架的歷史:
2010年,F(xiàn)acebook開始使用XHP框架,使PHP代碼生成HTML和JSX代碼。Facebook的前端工程師Jordan Walke開始研究在JavaScript中實現(xiàn)類似的功能。
2011年,Jordan Walke創(chuàng)建了內部項目JSX,并在Facebook的廣告實驗室中使用。
2012年,F(xiàn)acebook開始使用React構建他們自己的產(chǎn)品,并將React項目開源。
2013年,React首次發(fā)布,React被認為是一個“視圖”庫,而不是一個完整的MVC框架。
2015年,React Native發(fā)布,用于構建iOS和Android應用程序。
2016年,React的版本15發(fā)布,支持Fiber架構,F(xiàn)iber是一種將React組件渲染成底層平臺原生UI元素的新實現(xiàn)方式,可提高性能和可維護性。
2017年,React發(fā)布了版本16,其中包括對React Fiber架構的完整支持。
2018年,React 16.6發(fā)布,其中包括React Hooks功能,允許開發(fā)人員在不使用類的情況下使用React狀態(tài)和其他React功能。
2019年,React 16.9發(fā)布,其中包括鉤子API的更新和性能優(yōu)化。
React框架已經(jīng)成為web開發(fā)中最受歡迎的框架之一,其在社區(qū)和工業(yè)中有著廣泛的應用。

搭建效果:

?搭建react ts項目

create-react-app 工具

create-react-app 是一個用于自動化 React 項目搭建的命令行工具。它可以幫助開發(fā)者快速創(chuàng)建一個基于 React 的項目結構,并且集成了常用的開發(fā)工具和配置,例如 webpack、Babel、ESLint 等。
create-react-app 可以幫助開發(fā)者避免手動配置項目結構和工具鏈的繁瑣過程,讓開發(fā)者能夠更專注于項目的核心邏輯開發(fā)。同時,create-react-app 中的配置也經(jīng)過了官方和社區(qū)的廣泛驗證和優(yōu)化,具有很好的性能和可用性。
使用 create-react-app 只需要簡單幾步操作,就能創(chuàng)建一個完整的、可用的 React 項目。同時,create-react-app 也提供了豐富的命令行工具,可以幫助開發(fā)者快速啟動、構建和測試項目。

使用 create-react-app 腳手架,創(chuàng)建ts的模板類型

$ npx create-react-app my-app --template typescript

?引入grapes 插件

grapes插件簡介

Grapes插件是一種用于Web開發(fā)的開源工具,可以幫助用戶快速創(chuàng)建動態(tài)和交互式的網(wǎng)頁元素。它基于Javascript和CSS,提供了豐富的可定制的組件和模板,使用戶可以快速創(chuàng)建和定制網(wǎng)頁元素,如按鈕、表格、圖表、彈框等等。Grapes插件還提供了一個易于使用的UI編輯器,使得用戶可以通過拖放和調整組件屬性來創(chuàng)建和編輯網(wǎng)頁元素。此外,它還支持多語言和多瀏覽器,適合開發(fā)響應式網(wǎng)頁和移動應用程序。

安裝grapes依賴

$ npm i grapesjs

官網(wǎng)案例:

<link rel="stylesheet" href="path/to/grapes.min.css" rel="external nofollow" >
<script src="path/to/grapes.min.js"></script>
<div id="gjs"></div>
<script type="text/javascript">
  var editor = grapesjs.init({
      container : '#gjs',
      components: '<div class="txt-red">Hello world!</div>',
      style: '.txt-red{color: red}',
  });
</script>

主頁配置app.tsx

import './App.css';
import 'grapesjs/dist/css/grapes.min.css';
import grapesjs from 'grapesjs';
import { useState } from 'react';
import PresetPage from './views/PresetPage'
import EmailPage from './views/EmailPage'
import GrapesPage from './views/GrapesPage'
import  {sendEmail} from './service/sendEmailApi'
function App() {
  const [editType,setEditType]=useState('mjml');
  const changeEditype=(val:string)=>{
    setEditType(val)
  };
  return (
      <div className="App">
        <header className="App-header">
          <div style={{width:'50%',textAlign:'left',paddingLeft:'10px'}}>
              grapes web插件 對比
              <button style={{marginLeft:'20px'}} onClick={()=>changeEditype('grapejs')}>grapejs</button>
              <button style={{marginLeft:'20px'}} onClick={()=>changeEditype('mjml')}>mjml</button>
              <button style={{margin:'0 20px'}} onClick={()=>changeEditype('preset')}>preset newsletter</button>
              當前的插件類型:{editType}
        </header>
        {editType==='grapejs'&&<GrapesPage editInstance={grapesjs}></GrapesPage>}
        {editType==='mjml'&&<EmailPage editInstance={grapesjs}></EmailPage>}
        {editType==='preset'&&<PresetPage editInstance={grapesjs}></PresetPage>}
      </div>
  );
}
export default App;

grapePage.tsx

import { useEffect, useState } from 'react'
const GrapesPage=(props:any)=>{
    const [editor,setEditor]=useState();
    const [domRef,setDomRef]=useState();
    const renderGrape = () => {
        if(domRef&&!editor){
            // @ts-ignore
            const editorInstance:any = props.editInstance
                .init({
                    container: '#gjs-grapes',
                });
            setEditor(editorInstance)
        }
    }
    useEffect(()=>{
        renderGrape()
    },[renderGrape])
    return (
        <div id={'gjs-grapes'} style={{
    width: '800px',
    height: '800px'
}}
    ref={(ref: any) => {
        setDomRef(ref)
    }}
    />
    )
};
export default GrapesPage

效果:

github倉庫建設demo:https://github.com/yongma16/grapes-mjml-react

屬于一個測試demo。

到此這篇關于react搭建在線編輯html的站點——引入grapes實現(xiàn)在線拖拉拽編輯html的文章就介紹到這了,更多相關react在線編輯html的站點內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • React Fragment 和空標簽(<></>)用法及區(qū)別詳解

    React Fragment 和空標簽(<></>)用法及區(qū)別詳解

    本文詳細介紹了React中的Fragment和空標簽的使用,包括它們的區(qū)別、使用場景、性能考慮以及最佳實踐,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2025-01-01
  • antd form表單如何處理自定義組件

    antd form表單如何處理自定義組件

    這篇文章主要介紹了antd form表單如何處理自定義組件問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • React Router 如何使用history跳轉的實現(xiàn)

    React Router 如何使用history跳轉的實現(xiàn)

    這篇文章主要介紹了React Router 如何使用history跳轉的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • React的diff算法核心復用圖文詳解

    React的diff算法核心復用圖文詳解

    這篇文章主要為大家介紹了React的diff算法核心復用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • create-react-app修改為多頁面支持的方法

    create-react-app修改為多頁面支持的方法

    本篇文章主要介紹了create-react-app修改為多頁面支持的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Remix 后臺桌面開發(fā)electron-remix-antd-admin

    Remix 后臺桌面開發(fā)electron-remix-antd-admin

    這篇文章主要為大家介紹了Remix 后臺桌面開發(fā)electron-remix-antd-admin的過程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • React項目開發(fā)中函數(shù)組件與函數(shù)式編程關系

    React項目開發(fā)中函數(shù)組件與函數(shù)式編程關系

    函數(shù)組件和函數(shù)式編程究竟是什么關系呢?本文會圍繞這個話題展開講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • React+Typescript項目環(huán)境搭建并使用redux環(huán)境的詳細過程

    React+Typescript項目環(huán)境搭建并使用redux環(huán)境的詳細過程

    這篇文章主要介紹了React+Typescript項目環(huán)境搭建并使用redux環(huán)境的詳細過程,本文通過圖文實例相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • React實現(xiàn)antdM的級聯(lián)菜單實例

    React實現(xiàn)antdM的級聯(lián)菜單實例

    這篇文章主要為大家介紹了React實現(xiàn)antdM的級聯(lián)菜單實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • react實現(xiàn)pure render時bind(this)隱患需注意!

    react實現(xiàn)pure render時bind(this)隱患需注意!

    這篇文章主要為大家詳細介紹了值得你在react實現(xiàn)pure render的時候,需要注意的bind(this)隱患,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03

最新評論