EmployeeNumber =
string.IsNullOrEmpty(employeeNumberTextBox.Text)
? null
: Convert.ToInt32(employeeNumberTextBox.Text),
我经常发现自己想做这样的事情(因为它EmployeeNumber
是Nullable<int>
LINQ-to-SQL dbml 对象的属性,其中列允许 NULL 值)。不幸的是,编译器认为
'null' 和 'int' 之间没有隐式转换
即使这两种类型在对它们自己的可为空的 int 的赋值操作中都是有效的。
据我所知,使用空合并运算符不是一个选项,因为.Text
如果字符串不为空,则需要在字符串上进行内联转换。
据我所知,这样做的唯一方法是使用 if 语句和/或分两步分配它。在这种特殊情况下,我发现这非常令人沮丧,因为我想使用对象初始化器语法,而这个赋值将在初始化块中......
有谁知道更优雅的解决方案?