zoukankan      html  css  js  c++  java
  • ios开发应用内实现多语言自由切换

    需求描述:应用内部有一按钮,点击切换语言(如中英文切换)。
    说起来这个是好久以前做的一个功能点了,刚开始也是没有头绪,后来解决了发现很简单,把方法分享一下。
    1.原理。
    查看NSLocalizedString(@"abc",nil);的定义。

    1
    2
    #define NSLocalizedString(key, comment)
            [[NSBundle mainBundle] localizedStringForKey:(key) value:@"" table:nil]


    然后思考,为什么这个定义会定位到当前系统默认的语言对应的strings文件呢?
    如果这点想通了,那问题就迎刃而解了不是?

    2.具体解析
    重定义NSLocalizedstring。

    1
    2
    3
    #define AppLanguage @"appLanguage"
    #define CustomLocalizedString(key, comment)
    [[NSBundle bundleWithPath:[[NSBundle mainBundle] pathForResource:[NSString stringWithFormat:@"%@",[[NSUserDefaults standardUserDefaults] objectForKey:@"appLanguage"]] ofType:@"lproj"]] localizedStringForKey:(key) value:@"" table:nil]


    不用解释了吧?查找对应的strings文件。

    3.用法

    1
    2
    3
    4
         if (![[NSUserDefaults standardUserDefaults]objectForKey:AppLanguage]) {
                [[NSUserDefaults standardUserDefaults] setObject:@"zh-Hans" forKey:AppLanguage];
            }
    label.text= CustomLocalizedString(@"sub_menu_download", nil);//@"离线下载";



    4.切换
    点击中英文切换按钮时,

    1
    2
    3
    4
    5
    6
    7
    8
    NSString *currentLanguage = [[NSUserDefaults standardUserDefaults]objectForKey:AppLanguage];
            if ([currentLanguage isEqualToString: @"en"]) {
                [[NSUserDefaults standardUserDefaults] setObject:@"zh-Hans" forKey:AppLanguage];
            }else
            {
                [[NSUserDefaults standardUserDefaults] setObject:@"en" forKey:AppLanguage];
            }
            [[NSUserDefaults standardUserDefaults] synchronize];


    程序还要再做进一步的界面相关的处理,如是tabbar则重新初始化等等

  • 相关阅读:
    Spark-sql windows 下 执行错误.
    notepad ++ 注册表
    log4j 配置文件 示例
    linux 查看 进程 内存占用
    spring boot 常见错误解决
    python 轻量 web 框架 Bottle 使用
    Spring cloud eureka 添加 spring-security
    vue can‘ not resolver sass-loader 的 解决办法。
    外国人眼中的珍珠奶茶是啥?
    75.2亿美元:诺基亚、微软终于在一起
  • 原文地址:https://www.cnblogs.com/Free-Thinker/p/5478716.html
Copyright © 2011-2022 走看看