diff --git a/src/components/TaskForm.tsx b/src/components/TaskForm.tsx index 5d7d5f6..f99fbc0 100644 --- a/src/components/TaskForm.tsx +++ b/src/components/TaskForm.tsx @@ -99,7 +99,7 @@ const TaskForm: React.FC = ({ task, onTaskChange }) => { 任务名称 onTaskChange({ ...task, name: text })} inputContainerStyle={styles.inputContainer} inputStyle={styles.inputText} diff --git a/src/screens/TaskEditScreen.tsx b/src/screens/TaskEditScreen.tsx index 8760296..d2662e2 100644 --- a/src/screens/TaskEditScreen.tsx +++ b/src/screens/TaskEditScreen.tsx @@ -39,14 +39,26 @@ export default function TaskEditScreen() { useEffect(() => { const loadTask = async () => { let taskData = getTaskById(taskId); - debugger; + console.log('taskData', taskData); + if (taskData && !taskData.detail) { await fetchTaskDetail(taskId); taskData = getTaskById(taskId); } if (taskData) { - setTask(taskData); - setOriginalTask(taskData); + // 在这里处理 detail 字段 + let processedTask = { ...taskData }; + if (processedTask.detail && typeof processedTask.detail === 'string') { + try { + processedTask.detail = JSON.parse(processedTask.detail); + } catch (e) { + console.error('解析任务详情失败:', e); + // 解析失败,可以根据业务需求决定如何处理,比如清空detail + processedTask.detail = undefined; + } + } + setTask(processedTask); + setOriginalTask(processedTask); } }; loadTask();