action的一个初始化加载的问题

本文探讨了在Struts与Spring集成时,由于配置导致的Action类属性与全局Bean同名引发的注入冲突问题,并提出了避免此类问题的方法。
 

  刚才做项目,发现一个很恶心人的问题:

  我们在做sturts与spring的集成之后,由于struts与spring-plugin的关系,所有的bean会在web系统启动的时候全部初始化!当然action此时也会被初始化!而action在初始化的时候,其中有一个默认的配置属性 struts.objectFactory.spring.autoWire 这个属性会自动在action初始化的时候将action的属性按名字给注入进来,如此带来的问题是,既然所有的bean都被初始化,如果此时action 类中有一个属性名和一个ActionBean的名字一样,action会把这个actionbean给注入到这个属性里,如此导致这个恶心的错误!

   @component("user")//这个Useraction的名字

   public class UserAction extends ActionSupport implements ModelDriven{

     private User user;

     public void getUser(){

       return user;

     }

     public User setUser(User user){

     this.user=user; 

     }

     private String username;

     public void getUserName(){

       return userName;

     }

     public User setUserName(UserName userName){

     this.userName=userName; 

     }

  }

  在系统启动初始化完成后内存中就有一个叫user的bean(UserAction)而UserAction中有一个属性user和这个bean同名,所以依照配置如果名字相同就会把这个bean注入给这个属性,就导致了类型不能转化的错误发生!比较恶心,而且无论你对struts.objectFactory.spring.autoWire这个属性做任何的配置都还是没有任何效果,除非你禁止掉这个filter过滤器,但是如果这样你就更悲剧了,你要重写一个filter来完成系统初始化时所做的注入操作!

  唯一的解决方案就是再用annotation时不要把bean的名字和属性的名字写成一样的!

### Vue3 中实现初始化时的全屏加载动画 在 Vue3 项目中,可以通过组合式 API 或选项式 API 来实现初始化时的全屏加载动画。以下是具体的实现方法: #### 1. 创建全局 Loading 组件 可以创建一个独立的 `Loading` 组件用于显示加载动画。此组件可以在应用启动时自动挂载。 ```vue <template> <div v-if="isLoading" class="loading-overlay"> <div class="spinner"></div> </div> </template> <script> import { ref, onMounted, onUnmounted } from 'vue'; export default { setup() { const isLoading = ref(true); // 模拟异步数据加载完成后隐藏加载动画 setTimeout(() => { isLoading.value = false; }, 2000); // 延迟两秒模拟加载时间 return { isLoading }; }, }; </script> <style scoped> .loading-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(255, 255, 255, 0.8); display: flex; justify-content: center; align-items: center; z-index: 9999; } .spinner { border: 4px solid #f3f3f3; /* Light grey */ border-top: 4px solid #3498db; /* Blue */ border-radius: 50%; width: 50px; height: 50px; animation: spin 1s linear infinite; } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } </style> ``` 上述代码定义了一个简单的旋转加载动画,并通过 `setTimeout` 模拟了延迟关闭的效果[^1]。 #### 2. 将 Loading 组件嵌入 App.vue 为了使加载动画在整个应用程序范围内生效,可以直接将其嵌套到根组件 `App.vue` 中。 ```vue <template> <div id="app"> <!-- 加载动画 --> <Loading /> <!-- 应用主体 --> <router-view></router-view> </div> </template> <script> import Loading from './components/Loading.vue'; export default { components: { Loading }, }; </script> ``` 这样,当应用首次加载时,`Loading` 组件会立即呈现并覆盖整个屏幕,直到其内部逻辑决定停止展示为止。 #### 3. 结合 Vuex 或 Pinia 进行动态控制(可选) 如果希望更灵活地管理加载状态,可以引入状态管理工具如 Vuex 或 Pinia。例如,在 Pinia 中设置一个共享的状态变量来控制加载行为。 ```javascript // store/loading.js import { defineStore } from 'pinia'; export const useLoadingStore = defineStore('loading', { state: () => ({ isLoading: true, }), actions: { finishLoading() { this.isLoading = false; }, }, }); ``` 随后修改 `Loading.vue` 使用该 Store 控制可见性: ```javascript import { computed } from 'vue'; import { useLoadingStore } from '@/store/loading'; export default { setup() { const loadingStore = useLoadingStore(); const isLoading = computed(() => loadingStore.isLoading); setTimeout(() => { loadingStore.finishLoading(); // 调用 action 完成加载 }, 2000); return { isLoading }; }, }; ``` 这种设计允许其他模块显式通知何时结束加载过程[^2]。 --- #### 性能优化建议 - **懒加载资源**:对于非必要的静态文件或第三方库,考虑按需加载以减少初始包大小。 - **骨架屏替代方案**:除了传统的圆形进度条外,还可以采用占位符形式的内容预览作为过渡效果,提升用户体验感知速度[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值