当前位置: 首页 > wzjs >正文

如何建论坛网站seo关键词排名优化评价

如何建论坛网站,seo关键词排名优化评价,室内设计学校比较好,如何在赌博网站做代理继上篇博客的需求开发,选择joditEditor进行项目开发。开发过程中实现编辑和预览两种场景,浅浅的记录一下思路~1.编辑文件引入封装后的joditEditor组件useEffect(() > {if (value) {form.setFieldsValue(value);// 如果有内容,需…

继上篇博客的需求开发,选择joditEditor进行项目开发。开发过程中实现编辑和预览两种场景,浅浅的记录一下思路~

1.编辑文件引入封装后的joditEditor组件

  useEffect(() => {if (value) {form.setFieldsValue(value);// 如果有内容,需要设置在编辑器中if (value.content && joditValueRef.current) {joditValueRef.current.setContent(value.content);}}}, [value, form]);

第一次输入内容后展示效果:

点击save按钮,保存文本内容,进入preview模式,如下步骤

2.预览文件引入封装后的joditEditor组件

<div style={{ marginTop: '20px' }}><JoditVariableEditor mode={'preview'} value={value.content} />
</div>

3.修改joditEditor组件

新增mode和value两个props传入该组件

3.1、监听value,声明joditValue变量,将编辑内容抛给父组件(getContent、setContent)

import JoditEditor from 'jodit-react';
import {forwardRef,useEffect,useImperativeHandle,useRef,useState,
} from 'react';
import styles from './index.less';const JoditVariableEditor = ({ mode, value }: any, ref: any) => {const editorRef = useRef<any>(null);const [joditValue, setJoditValue] = useState<any>(value || null);// 当 value 变化时更新编辑器内容,用于预览useEffect(() => {if (value) {const editorElement = document.querySelector('.jodit-wysiwyg',) as HTMLElement;if (editorElement) {editorElement.innerHTML = value;}}setJoditValue(value);}, [value]);// 拖拽到编辑器时插入变量const handleDrop = (e: React.DragEvent<HTMLDivElement>) => {e.preventDefault();const text = e.dataTransfer.getData('text/plain');const jodit = editorRef.current?.getEditor();if (text && jodit) {jodit.selection.insertHTML(text);}};// 将blob URL转换为base64const convertBlobUrlToBase64 = async (blobUrl: string): Promise<string> => {try {// 从blob URL获取blob对象const response = await fetch(blobUrl);const blob = await response.blob();// 将blob转换为base64return new Promise((resolve, reject) => {const reader = new FileReader();reader.onloadend = () => resolve(reader.result as string);reader.onerror = reject;reader.readAsDataURL(blob);});} catch (error) {console.error('转换blob URL到base64失败:', error);return '';}};// 处理HTML内容中的所有图片const processHtmlContent = async (html: string): Promise<string> => {// 创建一个临时的DOM元素来解析HTMLconst tempDiv = document.createElement('div');tempDiv.innerHTML = html;// 查找所有图片元素const images = tempDiv.querySelectorAll('img');// 处理每个图片for (let i = 0; i < images.length; i++) {const img = images[i];const src = img.getAttribute('src');// 检查是否是blob URLif (src && src.startsWith('blob:')) {try {// 转换为base64const base64Data = await convertBlobUrlToBase64(src);img.setAttribute('src', base64Data);} catch (error) {console.error('处理图片失败:', error);}}}// 返回处理后的HTMLreturn tempDiv.innerHTML;};const handleDragOver = (e: React.DragEvent<HTMLDivElement>) => {e.preventDefault(); // 必须阻止默认行为才能触发drope.dataTransfer.dropEffect = 'copy'; // 显示为复制效果};useImperativeHandle(ref, () => ({getContent: async () => {if (editorRef.current) {const editorContent =document.querySelector('.jodit-wysiwyg')?.innerHTML || '';const processedContent = await processHtmlContent(editorContent);setJoditValue(processedContent);return processedContent;}return joditValue;},setContent: async (content: string) => {setJoditValue(content); // 编辑状态展示内容},}));return (<>     <divstyle={{// flex: 1,// minWidth: 0,// overflow: 'hidden',width: mode === 'preview' ? '100%' : 1000,marginTop: 10,}}onDrop={handleDrop}onDragOver={handleDragOver}onDragEnter={(e) => {e.preventDefault(); // 防止默认行为}}><JoditEditorref={editorRef}config={{height: 300,readonly: mode === 'preview', // 预览模式时设为只读toolbarSticky: false,uploader: { insertImageAsBase64URI: true },placeholder: '',showCharsCounter: false,showWordsCounter: false,showXPathInStatusbar: false,statusbar: false,width: '100%',style: {'max-width': '100%','word-wrap': 'break-word','overflow-wrap': 'break-word',},buttons: [// 预览模式时隐藏所有工具栏按钮'bold','italic','underline','strikethrough','|','ul','ol','indent','outdent','align','superscript','subscript','|','brush','font','fontsize','paragraph','image','table','link','|','cut','copy','paste','selectall','eraser','undo','redo','hr','find','fullsize','preview',],events: {drop: function (e) {console.log('Jodit editor drop event', e);},dragover: function (e) {console.log('Jodit editor dragover event', e);},},}}/></div></>);
};
export default forwardRef(JoditVariableEditor);

查看下预览模式:

点击右上角edit按钮,进入编辑模式,上次输入的内容正常展示!

stay hungry,stay foolish~~

http://www.dtcms.com/wzjs/116386.html

相关文章:

  • 网站建设行业发展史今日国内新闻大事件
  • iis配置网站无法访问百度官方网页
  • 上海网站制作工作室百度seo公司兴田德润
  • 网站建设培训教程有利于seo优化的是
  • iis wordpress衡水seo排名
  • 武汉做网站企业百度竞价排名服务
  • 网站更新的意义广告推销网站
  • 网站的图文链接怎么做成都百度推广联系方式
  • 网站如何做反链网上培训
  • 网站首页可以做竖版吗网络营销的原理
  • 手机搭建网站软件下载久久seo综合查询
  • 响应式网站导航怎么做办公软件速成培训班
  • iis 无法访问此网站直通车推广怎么做
  • 网站域名 被别人备案沈阳网站关键词排名
  • 东阿企业做网站推广武汉seo网站优化排名
  • 东莞网站建设设互联网品牌的快速推广
  • 网站地图提交长春做网站推广的公司
  • 山东网站方案百度竞价排名规则及费用
  • 怀化建设公司网站百度搜索电话
  • 南昌制作网站的公司吗百度教育官网
  • 免费商业网站模板广告推广接单平台
  • 中企动力做网站行吗自己做seo网站推广
  • 做网站一般收取多少钱app优化排名
  • 开发高端网站开发灰色关键词怎么做排名
  • 手机网站的文本排版是怎么做的公司网页设计
  • 项目网站建设方案模板关键字搜索引擎
  • seo网站制作天眼查询个人信息
  • 网站后台数据分析怎么做北京网站优化常识
  • c 做注册网站北京网络营销推广培训哪家好
  • 内蒙古交通建设质监局网站无锡网站制作推广