Non-static filed '' cannot be referenced from a static context

util类中无法调用service的解决办法

private static SysDictMapper dictMapper = SpringContextHolder.getBean(SysDictMapper.class);

SpringContextHolder.java文件

/**
 * Copyright &copy; 2012-2016 <a href="https://github.com/thinkgem/jeesite">JeeSite</a> All rights reserved.
 */
package com.youruan.logistics.util;

import org.apache.commons.lang3.Validate;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service;

/**
 * 以静态变量保存Spring ApplicationContext, 可在任何代码任何地方任何时候取出ApplicaitonContext.
 *
 * @author zhangsanfeng
 * @date 2013-5-29 下午1:25:40
 */
@Service
@Lazy(false)
public class SpringContextHolder implements ApplicationContextAware, DisposableBean {

    private static ApplicationContext applicationContext = null;

    private static Logger logger = LoggerFactory.getLogger(SpringContextHolder.class);

    /**
     * 取得存储在静态变量中的ApplicationContext.
     */
    public static ApplicationContext getApplicationContext() {
        assertContextInjected();
        return applicationContext;
    }

    /**
     * 实现ApplicationContextAware接口, 注入Context到静态变量中.
     */
    @Override
    public void setApplicationContext(ApplicationContext applicationContext) {
//    logger.debug("注入ApplicationContext到SpringContextHolder:{}", applicationContext);
//    if (SpringContextHolder.applicationContext != null) {
//       logger.info("SpringContextHolder中的ApplicationContext被覆盖, 原有ApplicationContext为:" + SpringContextHolder.applicationContext);
//    }
        SpringContextHolder.applicationContext = applicationContext;
    }

    /**
     * 从静态变量applicationContext中取得Bean, 自动转型为所赋值对象的类型.
     */
    @SuppressWarnings("unchecked")
    public static <T> T getBean(String name) {
        assertContextInjected();
        return (T) applicationContext.getBean(name);
    }

    /**
     * 从静态变量applicationContext中取得Bean, 自动转型为所赋值对象的类型.
     */
    public static <T> T getBean(Class<T> requiredType) {
        assertContextInjected();
        return applicationContext.getBean(requiredType);
    }

    /**
     * 清除SpringContextHolder中的ApplicationContext为Null.
     */
    public static void clearHolder() {
        if (logger.isDebugEnabled()) {
            logger.debug("清除SpringContextHolder中的ApplicationContext:" + applicationContext);
        }
        applicationContext = null;
    }

    /**
     * 检查ApplicationContext不为空.
     */
    private static void assertContextInjected() {
        Validate.validState(applicationContext != null, "applicaitonContext属性未注入, 请在applicationContext.xml中定义SpringContextHolder.");
    }

    /**
     * 实现DisposableBean接口, 在Context关闭时清理静态变量.
     */
    @Override
    public void destroy() throws Exception {
        SpringContextHolder.clearHolder();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要设置多级表头,你需要使用 `vue3-json-excel` 的 `multiHeader` 选项。这个选项接受一个二维数组,其中每个子数组代表一行表头,每个元素代表一个表头单元格。如果某个单元格需要跨越多列或多行,你可以使用 `colSpan` 和 `rowSpan` 属性来指定跨越的列数和行数。 下面是一个示例代码,其中设置了一个两级表头: ```html <template> <vue-json-excel :data="tableData" :columns="tableColumns" :multiHeader="tableMultiHeaders" :filename="filename" :export-type="exportType" /> </template> <script> import VueJsonExcel from 'vue3-json-excel' export default { components: { VueJsonExcel }, data() { return { filename: 'my_excel_file', exportType: 'xls', tableData: [ { id: 1, name: 'John', age: 28, gender: 'Male' }, { id: 2, name: 'Alice', age: 24, gender: 'Female' }, { id: 3, name: 'Bob', age: 32, gender: 'Male' }, { id: 4, name: 'Charlie', age: 45, gender: 'Male' } ], tableColumns: ['id', 'name', 'age', 'gender'], tableMultiHeaders: [ ['Personal Information', '', '', ''], ['ID', 'Name', 'Age', 'Gender'] ] } } } </script> ``` 在上面的代码中,我们定义了一个 `tableMultiHeaders` 数组,其中第一个子数组表示第一行表头,第二个子数组表示第二行表头。第一行表头的第一个单元格跨越了四列,因此我们在这个单元格中设置了 `colSpan: 4`。第二行表头没有跨越单元格,因此我们只需要设置每个单元格的文本即可。 你可以根据自己的需求修改这个示例代码,以达到你想要的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值