随笔记录

优化Android页面背景
本文介绍了一种优化Android应用首页背景加载的方法,通过在onDestroy()方法中释放背景资源,避免内存泄漏并提高页面加载速度。

1.getwindow().setbackgrounddrawable(),这个方法也是给页面的根view设置的背景,即使我们没有调用setcontentview()这个方法也一样。那么例如app首页我们往往只会在主题中设置背景图片,来提高页面显示速度,此时我们应该这么优化页面:

@Override
    protected void onDestroy() {
        if (null != getWindow()) {
            Drawable background = getWindow().getDecorView().getBackground();
            if (null != background && background instanceof BitmapDrawable) {
                getWindow().setBackgroundDrawable(null);
                background.setCallback(null);
                AppUtils.recycleBitmap(((BitmapDrawable) background).getBitmap());
            }
        }
        super.onDestroy();
    }
public static void recycleBitmap(Bitmap... bitmaps) {
        for (Bitmap bitmap : bitmaps) {
            if (null != bitmap && !bitmap.isRecycled()) {
                bitmap.recycle();
                bitmap = null;
            }
        }
        System.gc();
    }

 

### Vue 3 和 Vite 实现分包优化性能配置指南 在现代前端开发中,分包是一种有效的技术手段,用于减少初始加载时间并提高 Web 应用程序的整体性能。以下是基于 Vue 3 和 Vite 的分包优化策略。 #### 1. 使用 Rollup 插件实现动态导入 Vite 基于 Rollup 构建,因此可以利用其插件生态来实现按需加载和分包功能。通过 `import()` 动态语法,开发者能够将大文件拆分为多个小模块,在需要时才加载这些模块。这种方式显著减少了首屏渲染的时间[^1]。 ```javascript // 示例代码:组件懒加载 const MyComponent = () => import('./MyComponent.vue'); export default { components: { MyComponent } }; ``` #### 2. 配置 Vite 的 code-splitting 功能 Vite 自动支持 Code Splitting 技术,无需额外安装任何依赖即可启用此特性。只需确保项目中的路由或组件采用了异步引入的方式,则会自动生成对应的 chunk 文件[^4]。 ```javascript // vite.config.js 中开启 rollupOptions 进一步定制打包行为 import { defineConfig } from 'vite'; export default defineConfig({ build: { rollupOptions: { output: { manualChunks(id) { if (id.includes('node_modules')) { return id.toString().split('node_modules/')[1].split('/')[0]; } }, }, }, }, }); ``` #### 3. 结合 Uni-app 路由机制完成页面级分包 如果目标平台涉及多端适配(H5、小程序等),可参考 Uni-app 提供的 pages.json 配置方案来进行更细粒度的控制。例如设置独立入口文件或者指定某些特定路径下的资源作为子包处理[^3]。 ```json { "pages": [ { "path": "index", "style": {} } ], "subPackages": [{ "root": "packageA", // 子包根目录 "pages": [{...}] }] } ``` #### 4. 替换旧版响应式系统带来的优势 相较于 Vue 2 使用 Object.defineProperty 方法监听对象属性的变化,Vue 3 引入 Proxy 对象重构整个观察者模式,不仅解决了深嵌套结构难以追踪的问题,还极大提升了运行效率[^2]。这间接促进了大型应用分割后的流畅体验感。 --- ####
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值