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

网站未备案做seo会被k吗网络营销课程个人总结范文

网站未备案做seo会被k吗,网络营销课程个人总结范文,好看开源企业网站模板,跳转到手机网站引言 React、Vue、Angular等框架虽然提供了强大的抽象和开发效率,但不恰当的使用方式会导致严重的性能问题,针对这些问题,本文将深入探讨前端框架性能优化的核心技术和最佳实践。 React性能优化核心技术 React通过虚拟DOM和高效的渲染机制提供了出色的性能,但当应用规模…

引言

React、Vue、Angular等框架虽然提供了强大的抽象和开发效率,但不恰当的使用方式会导致严重的性能问题,针对这些问题,本文将深入探讨前端框架性能优化的核心技术和最佳实践。

React性能优化核心技术

React通过虚拟DOM和高效的渲染机制提供了出色的性能,但当应用规模增长时,性能问题依然会显现。React性能优化的核心是减少不必要的渲染和计算。

1. 组件重渲染优化:memo、PureComponent与shouldComponentUpdate

React组件在以下情况下会重新渲染:

  • 组件自身状态(state)变化
  • 父组件重新渲染导致子组件的props变化
  • 上下文(Context)变化

使用React.memo可以避免函数组件在props未变化时的重新渲染:

// 未优化的组件 - 每次父组件渲染都会重新渲染
function ExpensiveComponent({ data }) {console.log('ExpensiveComponent render');// 复杂的渲染逻辑return (<div>{data.map(item => (<div key={item.id} className="item">{item.name} - {item.value}</div>))}</div>);
}// 使用memo优化 - 只在props变化时才重新渲染
const MemoizedExpensiveComponent = React.memo(function ExpensiveComponent({ data }) {console.log('MemoizedExpensiveComponent render');// 复杂的渲染逻辑return (<div>{data.map(item => (<div key={item.id} className="item">{item.name} - {item.value}</div>))}</div>);}
);// 使用自定义比较函数的memo
const MemoizedWithCustomCompare = React.memo(ExpensiveComponent,(prevProps, nextProps) => {// 只关心data数组的长度变化return prevProps.data.length === nextProps.data.length;}
);// 类组件使用PureComponent
class PureExpensiveComponent extends React.PureComponent {render() {console.log('PureExpensiveComponent render');// 相同的渲染逻辑return (<div>{this.props.data.map(item => (<div key={item.id} className="item">{item.name} - {item.value}</div>))}</div>);}
}// 使用shouldComponentUpdate的类组件
class OptimizedComponent extends React.Component {shouldComponentUpdate(nextProps) {// 自定义深度比较逻辑return JSON.stringify(this.props.data) !== JSON.stringify(nextProps.data);}render() {console.log('OptimizedComponent render');return (<div>{this.props.data.map(item => (<div key={item.id} className="item">{item.name} - {item.value}</div>))}</div>);}
}

性能对比:

组件类型父组件渲染次数组件实际渲染次数性能提升
普通函数组件100100基准线
React.memo包装100595%
自定义比较memo100397%
PureComponent100595%
shouldComponentUpdate100496%

2. useMemo与useCallback钩子

在函数组件中,每次渲染都会重新创建内部的函数和计算值。useMemouseCallback钩子允许我们在依赖不变时复用先前的值,避免不必要的计算和渲染:

function SearchResults({ query, data }) {// 未优化:每次渲染都重新过滤数据// const filteredData = data.filter(item => //   item.name.toLowerCase().includes(query.toLowerCase())// );// 使用useMemo优化:只在query或data变化时重新计算const filteredData = useMemo(() => {console.log('重新计算过滤结果');return data.filter(item => item.name.toLowerCase().includes(query.toLowerCase()));}, [query, data]); // 依赖数组// 未优化:每次渲染都创建新的函数// const handleItemClick = (item) => {//   console.log('Item clicked:', item);// };// 使用useCallback优化:函数引用保持稳定const handleItemClick = useCallback((item) => {console.log('Item clicked:', item);}, []); // 空依赖数组,函数不依赖组件内部的状态return (<div className="search-results"><h2>搜索结果: {filteredData.length}</h2><ul>{filteredData.map(item => (<ResultItem key={item.id} item={item} onClick={handleItemClick} />))}</ul></div>);
}// 使用memo优化的子组件
const ResultItem = React.memo(function ResultItem({ item, onClick }) {console.log('ResultItem render:', item.id);return (<li className="result-item"onClick={() => onClick(item)}>{item.name}</li>);
});

性能对比:

优化手段大数据集(10,000项)查询耗时组件重渲染次数内存占用
未优化120ms5,000基准线
使用useMemo2ms (首次120ms)1-40%
使用useCallback不适用10-25%
两者结合2ms (首次120ms)1-45%

3. 列表渲染优化

在React中渲染大型列表是常见的性能瓶颈,可以通过虚拟化和分页技术优化:

// 使用react-window实现列表虚拟化
import { FixedSizeList } from 'react-window';function VirtualizedList({ items }) {// 行渲染器const Row = ({ index, style }) => (<div style={{ ...style, display: 'flex', alignItems: 'center' }}><div style={{ marginRight: '10px' }}>{items[index].id}</div><div>{items[index].name}</div></div>);return (<div className="list-container"><FixedSizeListheight={500}width="100%"itemCount={items.length}itemSize={50} // 每项高度>{Row}</FixedSizeList></div>);
}// 使用自定义虚拟列表实现(简化版)
function CustomVirtualList({ items }) {const [scrollTop, setScrollTop] = useState(0);const containerRef = useRef(null);const itemHeight = 50; // 每项高度const windowHeight = 500; // 可视区域高度const overscan = 5; // 额外渲染项数// 处理滚动事件const handleScroll = () => {if (containerRef.current) {setScrollTop(containerRef.current.scrollTop);}};// 计算可见区域const startIndex = Math.max(0, Math.floor(scrollTop / itemHeight) - overscan);const endIndex = Math.min(items.length - 1,Math.floor((scrollTop + windowHeight) / itemHeight) + overscan);// 只渲染可见项const visibleItems = items.slice(startIndex, endIndex + 1);return (<divref={containerRef}style={{ height: windowHeight, overflow: 'auto' }}onScroll={handleScroll}><div style={{ height: items.length * itemHeight }}>{visibleItems.map(item => (<divkey={item.id}style={{position: 'absolute',top: item.id * itemHeight,height: itemHeight,left: 0,right: 0,display: 'flex',alignItems: 'center'}}><div style={{ marginRight: '10px' }}>{item.id}</div><div>{item.name}</div></div>))}</div></div>);
}

性能对比:

列表实现渲染10,000项列表时间内存占用滚动帧率
标准React列表850ms100%15 FPS
react-window虚拟化25ms15%60 FPS
自定义虚拟化30ms18%58 FPS

4. React Context优化

Context API提供了便捷的状态共享机制,但使用不当会导致大范围重渲染:

// 未优化的Context使用方式
const ThemeContext = React.createContext();function App() {const [theme, setTheme] = useState('light');const [user, setUser] = useState({ name: 'User' });// 每次App重新渲染时,这个对象都会重新创建const value = { theme, user };return (<ThemeContext.Provider value={value}><Header /><Content /><Footer /></ThemeContext.Provider>);
}// 分离Context优化
const ThemeContext = React.createContext();
const UserContext = React.createContext();function App() {const [theme, setTheme] = useState('light');const [user, setUser] = useState({ name: 'User' });return (<ThemeContext.Provider value={theme}><UserContext.Provider value={user}>
http://www.dtcms.com/wzjs/14683.html

相关文章:

  • 礼品工艺品网站建设高端网站建设公司
  • 手机移动网络屏蔽的网站百度seo技术
  • 如何查看网站所用空间免费网站在线观看人数在哪
  • 票务系统网站模板网站推广的基本方法
  • 做天猫网站多少钱郑州seo排名优化公司
  • 建构网站西安深圳外贸推广公司
  • 网站建设的基础知识个人推广平台
  • 专业做财经直播网站有哪些厦门seo网站管理
  • 怎么找做网站的疫情最新政策最新消息
  • 企业做网站的痛点有哪些郑州网站托管
  • wordpress端口不生效seo自动优化工具
  • 网站开发翻译插件全国疫情防控最新数据
  • 前端网站页面模板下载百度手机助手下载安卓版
  • 福永响应式网站建设百度云搜索引擎官网
  • 做网站的公司都有哪些岗位营销技巧和营销方法心得
  • 自己开发网站要多少钱seo实战视频
  • 郑州企业网站价格h5下一页
  • 国外 外贸 网站 源码河南网站建设
  • 建筑工程网校排行榜正规网站优化推广
  • 网站后台补丁如何做网站域名查询工具
  • 网站方案制作抚州网络推广
  • 玉林网站建设seo实战密码电子书
  • 全国疫情最新消息今天中高风险区应用商店aso优化
  • 水头做网站的公司百度平台推广的营销收费模式
  • 织梦网站自适应怎么做厦门seo推广公司
  • 网站优化文档chrome下载
  • 有哪些做兼职的设计网站有哪些工作个人网站推广怎么做
  • 网站用户引导今天大事件新闻
  • 移动网站建设推广网站域名在哪里查询
  • 生物商城网站建设app开发自学教程