不能无条件调用运算符“*”,因为接收器可以为“null”。尝试向目标添加空检查 ('!')

时间:2021-04-07 12:24:35

标签: flutter dart flutter-web dart-null-safety

我使用此代码在我的 UI 中提高响应能力。所以这段代码的主要作用是计算屏幕的大小,我使用下面的函数根据 Figma 或 Adob​​e XD 中提供给我的设计来放置确切的字体大小。使用这种方法,我能够创建像素完美的用户界面。

升级到 Flutter 2.0.3 后,我收到空安全错误。我能够解决其中的大部分问题,但无法解决此错误。 请指教。

Complete Code

import 'package:flutter/material.dart';

class SizeConfig {
  static MediaQueryData? _mediaQueryData;
  static double? screenWidth;
  static double? screenHeight;
  static double? defaultSize;
  static Orientation? orientation;

  void init(BuildContext context) {
    _mediaQueryData = MediaQuery.of(context);
    screenWidth = _mediaQueryData!.size.width;
    screenHeight = _mediaQueryData!.size.height;
    orientation = _mediaQueryData!.orientation;
    if (orientation == Orientation.landscape) {
      defaultSize = screenHeight! * 0.024;
    } else {
      defaultSize = screenWidth! * 0.024;
    }
  }
}

double getSize(double size) {
  var defaultsSize = SizeConfig.defaultSize * size;
  return (defaultsSize / 10);
}

// Get the proportionate height as per screen size
double getProportionateScreenHeight(double inputHeight) {
  double screenHeight = SizeConfig.screenHeight!;
  // 812 is the layout height that designer use
  return (inputHeight / 812.0) * screenHeight;
}

// Get the proportionate width as per screen size
double getProportionateScreenWidth(double inputWidth) {
  double screenWidth = SizeConfig.screenWidth!;
  // 375 is the layout width that Figma provides
  return (inputWidth / 375.0) * screenWidth;
}

Error

3 个答案:

答案 0 :(得分:2)

因为 SizeConfig.defaultSize 可以为 null,所以你需要确保它的值不应该为 null。

您可以添加一些断言来通知调用者应该先初始化 SizeConfig。然后,您可以将其更改为 SizeConfig.defaultSize!

示例...

double getSize(double size) {
  assert(
    SizeConfig.defaultSize != null,
    "SizeConfig should be initialized (only once) before calling getSize(...). Refer to SizeConfig.init(...).",
  );
  var defaultsSize = SizeConfig.defaultSize! * size;
  return (defaultsSize / 10);
}

答案 1 :(得分:2)

您有三个选择:

  • 使用 bang 运算符:
int? count = 1;

void main() {
  // will throw an error if count is null
  print(count! * 2);
}
  • 使用 ??操作员:
int? count = 1;

void main() {
  // safe
  print((count ?? 1) * 2);
}
  • 使用 if - else 语句:
int? count = 1;

void main() {
  if(count != null) {
    print(count! * 2);
  } else {
    print('count is null');
  }
}

答案 2 :(得分:1)

问题:

您收到此错误是因为您在其上调用 * 的对象可能是 null

示例:

int? count = 1;

void main() {
  print(count * 2); // error: The operator '*' can't be unconditionally invoked ...
}

解决方案:

  • 使用局部变量:

    int? count = 1;
    
    void main() {
      var i = count;
      if (i != null) {
        print(i * 2); // Prints 2
      }
    }
    
  • 使用 bang 运算符 (!)

    int? count = 1;
    
    void main() {
      print(count! * 2); // Prints 2
    }