JSON NSMutableArray 类型的值无法转换为 NSString
JSON value of type NSMutableArray cannot be converted to NSString
描述
我刚刚在 Android 中安装了模块并实现了示例示例,它工作正常,但我在 iOS 中遇到了问题。当我通过单击消除来消除错误时,它对我有用。我还附上了示例代码。
我认为这是一个内部问题。
预期行为
打开日历而不出现此错误。
错误信息:
JSON value '(
{
label = increment;
name = increment;
},
{
label = decrement;
name = decrement;
}
)' of type NSMutableArray cannot be converted to NSString
+[RCTConvert NSString:]
RCTConvert.m:56
__49-[RCTComponentData createPropBlock:isShadowView:]_block_invoke.97
__49-[RCTComponentData createPropBlock:isShadowView:]_block_invoke_2.98
__49-[RCTComponentData propBlockForKey:isShadowView:]_block_invoke_2
RCTPerformBlockWithLogFunction
RCTPerformBlockWithLogPrefix
__49-[RCTComponentData propBlockForKey:isShadowView:]_block_invoke
__37-[RCTComponentData setProps:forView:]_block_invoke
__NSDICTIONARY_IS_CALLING_OUT_TO_A_BLOCK__
-[__NSDictionaryM enumerateKeysAndObjectsWithOptions:usingBlock:]
-[RCTComponentData setProps:forView:]
__50-[RCTUIManager createView:viewName:rootTag:props:]_block_invoke.405
__44-[RCTUIManager flushUIBlocksWithCompletion:]_block_invoke
__44-[RCTUIManager flushUIBlocksWithCompletion:]_block_invoke.461
__RCTExecuteOnMainQueue_block_invoke
_dispatch_call_block_and_release
_dispatch_client_callout
_dispatch_main_queue_callback_4CF
__CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__
__CFRunLoopRun
CFRunLoopRunSpecific
GSEventRunModal
UIApplicationMain
main
start
0x0
环境
react-native-calendars
: "^1.264.0"
react-native
: "^0.58.5"
react
: "16.8.6"
我认为 accessibilityActions
中有错误:
路径:./node_modules/react-native-calendars/src/calendar/header/index.js.
import React, {Component} from 'react';
import {ActivityIndicator, Platform} from 'react-native';
import {View, Text, TouchableOpacity, Image} from 'react-native';
import XDate from 'xdate';
import PropTypes from 'prop-types';
import styleConstructor from './style';
import {weekDayNames} from '../../dateutils';
import {CHANGE_MONTH_LEFT_ARROW, CHANGE_MONTH_RIGHT_ARROW} from '../../testIDs';
class CalendarHeader extends Component {
static displayName = 'IGNORE';
static propTypes = {
theme: PropTypes.object,
hideArrows: PropTypes.bool,
month: PropTypes.instanceOf(XDate),
addMonth: PropTypes.func,
showIndicator: PropTypes.bool,
firstDay: PropTypes.number,
renderArrow: PropTypes.func,
hideDayNames: PropTypes.bool,
weekNumbers: PropTypes.bool,
onPressArrowLeft: PropTypes.func,
onPressArrowRight: PropTypes.func,
disableArrowLeft: PropTypes.bool,
disableArrowRight: PropTypes.bool,
webAriaLevel: PropTypes.number
};
static defaultProps = {
monthFormat: 'MMMM yyyy',
webAriaLevel: 1
};
constructor(props) {
super(props);
this.style = styleConstructor(props.theme);
this.addMonth = this.addMonth.bind(this);
this.substractMonth = this.substractMonth.bind(this);
this.onPressLeft = this.onPressLeft.bind(this);
this.onPressRight = this.onPressRight.bind(this);
}
addMonth() {
this.props.addMonth(1);
}
substractMonth() {
this.props.addMonth(-1);
}
shouldComponentUpdate(nextProps) {
if (nextProps.month.toString('yyyy MM') !== this.props.month.toString('yyyy MM')) {
return true;
}
if (nextProps.showIndicator !== this.props.showIndicator) {
return true;
}
if (nextProps.hideDayNames !== this.props.hideDayNames) {
return true;
}
if (nextProps.firstDay !== this.props.firstDay) {
return true;
}
if (nextProps.weekNumbers !== this.props.weekNumbers) {
return true;
}
if (nextProps.monthFormat !== this.props.monthFormat) {
return true;
}
if (nextProps.renderArrow !== this.props.renderArrow) {
return true;
}
if (nextProps.disableArrowLeft !== this.props.disableArrowLeft) {
return true;
}
if (nextProps.disableArrowRight !== this.props.disableArrowRight) {
return true;
}
return false;
}
onPressLeft() {
const {onPressArrowLeft} = this.props;
if (typeof onPressArrowLeft === 'function') {
return onPressArrowLeft(this.substractMonth, this.props.month);
}
return this.substractMonth();
}
onPressRight() {
const {onPressArrowRight} = this.props;
if (typeof onPressArrowRight === 'function') {
return onPressArrowRight(this.addMonth, this.props.month);
}
return this.addMonth();
}
render() {
let leftArrow = <View/>;
let rightArrow = <View/>;
let weekDaysNames = weekDayNames(this.props.firstDay);
const {testID} = this.props;
if (!this.props.hideArrows) {
leftArrow = (
<TouchableOpacity
onPress={this.onPressLeft}
disabled={this.props.disableArrowLeft}
style={this.style.arrow}
hitSlop={{left: 20, right: 20, top: 20, bottom: 20}}
testID={testID ? `${CHANGE_MONTH_LEFT_ARROW}-${testID}`: CHANGE_MONTH_LEFT_ARROW}
>
{this.props.renderArrow
? this.props.renderArrow('left')
: <Image
source={require('../img/previous.png')}
style={this.props.disableArrowLeft ? this.style.disabledArrowImage : this.style.arrowImage}
/>}
</TouchableOpacity>
);
rightArrow = (
<TouchableOpacity
onPress={this.onPressRight}
disabled={this.props.disableArrowRight}
style={this.style.arrow}
hitSlop={{left: 20, right: 20, top: 20, bottom: 20}}
testID={testID ? `${CHANGE_MONTH_RIGHT_ARROW}-${testID}`: CHANGE_MONTH_RIGHT_ARROW}
>
{this.props.renderArrow
? this.props.renderArrow('right')
: <Image
source={require('../img/next.png')}
style={this.props.disableArrowRight ? this.style.disabledArrowImage : this.style.arrowImage}
/>}
</TouchableOpacity>
);
}
let indicator;
if (this.props.showIndicator) {
indicator = <ActivityIndicator color={this.props.theme && this.props.theme.indicatorColor}/>;
}
const webProps = Platform.OS === 'web' ? {'aria-level': this.props.webAriaLevel} : {};
return (
<View
style={this.props.style}
accessible
accessibilityRole={'adjustable'}
accessibilityActions={[
{name: 'increment', label: 'increment'},
{name: 'decrement', label: 'decrement'}
]}
onAccessibilityAction={this.onAccessibilityAction}
accessibilityElementsHidden={this.props.accessibilityElementsHidden} // iOS
importantForAccessibility={this.props.importantForAccessibility} // Android
>
<View style={this.style.header}>
{leftArrow}
<View style={{flexDirection: 'row'}}>
<Text
allowFontScaling={false}
style={this.style.monthText}
{...webProps}
>
{this.props.month.toString(this.props.monthFormat)}
</Text>
{indicator}
</View>
{rightArrow}
</View>
{!this.props.hideDayNames &&
<View style={this.style.week}>
{this.props.weekNumbers &&
<Text allowFontScaling={false} style={this.style.dayHeader}></Text>
}
{weekDaysNames.map((day, idx) => (
<Text
allowFontScaling={false}
key={idx}
style={this.style.dayHeader}
numberOfLines={1}
accessibilityLabel={''}
// accessible={false} // not working
// importantForAccessibility='no'
>
{day}
</Text>
))}
</View>
}
</View>
);
}
onAccessibilityAction = event => {
switch (event.nativeEvent.actionName) {
case 'decrement':
this.onPressLeft();
break;
case 'increment':
this.onPressRight();
break;
default:
break;
}
}
}
export default CalendarHeader;
通过将 react-native-calendar
降级到版本 ^1.260.0
解决
就运行npm i react-native-calendars@1.260.0 --save
然后清理并重建您的应用程序。
就我而言,我通过在警报对话框 https://reactnative.dev/docs/alert 中设置 message
属性 来解决它。
文档中没有要求,但当您设置了 onPress 操作时,它似乎会引发错误。
如果您不想设置 message
属性,只需像下面的代码一样传递一个空字符串:
Alert.alert('Booking Success', '', [
{ text: 'Close' },
{ text: 'View Details', onPress: () => console.log('test') },
]);
描述
我刚刚在 Android 中安装了模块并实现了示例示例,它工作正常,但我在 iOS 中遇到了问题。当我通过单击消除来消除错误时,它对我有用。我还附上了示例代码。 我认为这是一个内部问题。
预期行为
打开日历而不出现此错误。
错误信息:
JSON value '(
{
label = increment;
name = increment;
},
{
label = decrement;
name = decrement;
}
)' of type NSMutableArray cannot be converted to NSString
+[RCTConvert NSString:]
RCTConvert.m:56
__49-[RCTComponentData createPropBlock:isShadowView:]_block_invoke.97
__49-[RCTComponentData createPropBlock:isShadowView:]_block_invoke_2.98
__49-[RCTComponentData propBlockForKey:isShadowView:]_block_invoke_2
RCTPerformBlockWithLogFunction
RCTPerformBlockWithLogPrefix
__49-[RCTComponentData propBlockForKey:isShadowView:]_block_invoke
__37-[RCTComponentData setProps:forView:]_block_invoke
__NSDICTIONARY_IS_CALLING_OUT_TO_A_BLOCK__
-[__NSDictionaryM enumerateKeysAndObjectsWithOptions:usingBlock:]
-[RCTComponentData setProps:forView:]
__50-[RCTUIManager createView:viewName:rootTag:props:]_block_invoke.405
__44-[RCTUIManager flushUIBlocksWithCompletion:]_block_invoke
__44-[RCTUIManager flushUIBlocksWithCompletion:]_block_invoke.461
__RCTExecuteOnMainQueue_block_invoke
_dispatch_call_block_and_release
_dispatch_client_callout
_dispatch_main_queue_callback_4CF
__CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__
__CFRunLoopRun
CFRunLoopRunSpecific
GSEventRunModal
UIApplicationMain
main
start
0x0
环境
react-native-calendars
: "^1.264.0"react-native
: "^0.58.5"react
: "16.8.6"
我认为 accessibilityActions
中有错误:
路径:./node_modules/react-native-calendars/src/calendar/header/index.js.
import React, {Component} from 'react';
import {ActivityIndicator, Platform} from 'react-native';
import {View, Text, TouchableOpacity, Image} from 'react-native';
import XDate from 'xdate';
import PropTypes from 'prop-types';
import styleConstructor from './style';
import {weekDayNames} from '../../dateutils';
import {CHANGE_MONTH_LEFT_ARROW, CHANGE_MONTH_RIGHT_ARROW} from '../../testIDs';
class CalendarHeader extends Component {
static displayName = 'IGNORE';
static propTypes = {
theme: PropTypes.object,
hideArrows: PropTypes.bool,
month: PropTypes.instanceOf(XDate),
addMonth: PropTypes.func,
showIndicator: PropTypes.bool,
firstDay: PropTypes.number,
renderArrow: PropTypes.func,
hideDayNames: PropTypes.bool,
weekNumbers: PropTypes.bool,
onPressArrowLeft: PropTypes.func,
onPressArrowRight: PropTypes.func,
disableArrowLeft: PropTypes.bool,
disableArrowRight: PropTypes.bool,
webAriaLevel: PropTypes.number
};
static defaultProps = {
monthFormat: 'MMMM yyyy',
webAriaLevel: 1
};
constructor(props) {
super(props);
this.style = styleConstructor(props.theme);
this.addMonth = this.addMonth.bind(this);
this.substractMonth = this.substractMonth.bind(this);
this.onPressLeft = this.onPressLeft.bind(this);
this.onPressRight = this.onPressRight.bind(this);
}
addMonth() {
this.props.addMonth(1);
}
substractMonth() {
this.props.addMonth(-1);
}
shouldComponentUpdate(nextProps) {
if (nextProps.month.toString('yyyy MM') !== this.props.month.toString('yyyy MM')) {
return true;
}
if (nextProps.showIndicator !== this.props.showIndicator) {
return true;
}
if (nextProps.hideDayNames !== this.props.hideDayNames) {
return true;
}
if (nextProps.firstDay !== this.props.firstDay) {
return true;
}
if (nextProps.weekNumbers !== this.props.weekNumbers) {
return true;
}
if (nextProps.monthFormat !== this.props.monthFormat) {
return true;
}
if (nextProps.renderArrow !== this.props.renderArrow) {
return true;
}
if (nextProps.disableArrowLeft !== this.props.disableArrowLeft) {
return true;
}
if (nextProps.disableArrowRight !== this.props.disableArrowRight) {
return true;
}
return false;
}
onPressLeft() {
const {onPressArrowLeft} = this.props;
if (typeof onPressArrowLeft === 'function') {
return onPressArrowLeft(this.substractMonth, this.props.month);
}
return this.substractMonth();
}
onPressRight() {
const {onPressArrowRight} = this.props;
if (typeof onPressArrowRight === 'function') {
return onPressArrowRight(this.addMonth, this.props.month);
}
return this.addMonth();
}
render() {
let leftArrow = <View/>;
let rightArrow = <View/>;
let weekDaysNames = weekDayNames(this.props.firstDay);
const {testID} = this.props;
if (!this.props.hideArrows) {
leftArrow = (
<TouchableOpacity
onPress={this.onPressLeft}
disabled={this.props.disableArrowLeft}
style={this.style.arrow}
hitSlop={{left: 20, right: 20, top: 20, bottom: 20}}
testID={testID ? `${CHANGE_MONTH_LEFT_ARROW}-${testID}`: CHANGE_MONTH_LEFT_ARROW}
>
{this.props.renderArrow
? this.props.renderArrow('left')
: <Image
source={require('../img/previous.png')}
style={this.props.disableArrowLeft ? this.style.disabledArrowImage : this.style.arrowImage}
/>}
</TouchableOpacity>
);
rightArrow = (
<TouchableOpacity
onPress={this.onPressRight}
disabled={this.props.disableArrowRight}
style={this.style.arrow}
hitSlop={{left: 20, right: 20, top: 20, bottom: 20}}
testID={testID ? `${CHANGE_MONTH_RIGHT_ARROW}-${testID}`: CHANGE_MONTH_RIGHT_ARROW}
>
{this.props.renderArrow
? this.props.renderArrow('right')
: <Image
source={require('../img/next.png')}
style={this.props.disableArrowRight ? this.style.disabledArrowImage : this.style.arrowImage}
/>}
</TouchableOpacity>
);
}
let indicator;
if (this.props.showIndicator) {
indicator = <ActivityIndicator color={this.props.theme && this.props.theme.indicatorColor}/>;
}
const webProps = Platform.OS === 'web' ? {'aria-level': this.props.webAriaLevel} : {};
return (
<View
style={this.props.style}
accessible
accessibilityRole={'adjustable'}
accessibilityActions={[
{name: 'increment', label: 'increment'},
{name: 'decrement', label: 'decrement'}
]}
onAccessibilityAction={this.onAccessibilityAction}
accessibilityElementsHidden={this.props.accessibilityElementsHidden} // iOS
importantForAccessibility={this.props.importantForAccessibility} // Android
>
<View style={this.style.header}>
{leftArrow}
<View style={{flexDirection: 'row'}}>
<Text
allowFontScaling={false}
style={this.style.monthText}
{...webProps}
>
{this.props.month.toString(this.props.monthFormat)}
</Text>
{indicator}
</View>
{rightArrow}
</View>
{!this.props.hideDayNames &&
<View style={this.style.week}>
{this.props.weekNumbers &&
<Text allowFontScaling={false} style={this.style.dayHeader}></Text>
}
{weekDaysNames.map((day, idx) => (
<Text
allowFontScaling={false}
key={idx}
style={this.style.dayHeader}
numberOfLines={1}
accessibilityLabel={''}
// accessible={false} // not working
// importantForAccessibility='no'
>
{day}
</Text>
))}
</View>
}
</View>
);
}
onAccessibilityAction = event => {
switch (event.nativeEvent.actionName) {
case 'decrement':
this.onPressLeft();
break;
case 'increment':
this.onPressRight();
break;
default:
break;
}
}
}
export default CalendarHeader;
通过将 react-native-calendar
降级到版本 ^1.260.0
就运行npm i react-native-calendars@1.260.0 --save
然后清理并重建您的应用程序。
就我而言,我通过在警报对话框 https://reactnative.dev/docs/alert 中设置 message
属性 来解决它。
文档中没有要求,但当您设置了 onPress 操作时,它似乎会引发错误。
如果您不想设置 message
属性,只需像下面的代码一样传递一个空字符串:
Alert.alert('Booking Success', '', [
{ text: 'Close' },
{ text: 'View Details', onPress: () => console.log('test') },
]);