Description
Emoji characters render as [?] placeholder boxes in React Native <Text> components on the iOS 26 simulator (Xcode 26.3, build 17C529). This affects all emoji — inline, standalone, flag sequences, and Unicode escape sequences.
Safari running in the same simulator renders emoji correctly, confirming the font (AppleColorEmoji) is present and registered. The issue is specific to React Native's CoreText text rendering path.
Steps to reproduce
- Create a new React Native project (tested with RN 0.84.1 via
@react-native-community/cli)
- Add emoji to a
<Text> component:
<Text>Hello 🚀 World 🎨 Test ✅</Text>
<Text>Pure emoji: 😀😃😄😁😆😅🤣😂</Text>
<Text>Flags: 🇺🇸 🇨🇳 🇯🇵 🇬🇧</Text>
- Run on iOS 26 simulator (any device — iPhone 16, iPhone 17 Pro, etc.)
- All emoji appear as
[?] boxes
Expected behavior
Emoji should render using the AppleColorEmoji font, as they do in Safari and native UIKit apps on the same simulator.
Actual behavior
All emoji render as [?] replacement characters/boxes.
Environment
- React Native: 0.84.1 (also reproduced on 0.83.2)
- JS Engine: Hermes (also tested with JSC — same result)
- Architecture: New Architecture / Fabric (also tested with Old Architecture — same result)
- Xcode: 26.3 (build 17C529)
- iOS Simulator: 26.3.1 (23D8133)
- macOS: Darwin 25.3.0 (arm64)
Investigation done
- ✅ Confirmed
AppleColorEmoji-160px.ttc exists in the simulator runtime at CoreAddition/AppleColorEmoji-160px.ttc
- ✅ Confirmed font is registered (
CTFontManagerRegisterFontsForURL returns "already exists")
- ✅ Confirmed Safari in the same simulator renders emoji correctly
- ✅ Tested Hermes vs JSC — no difference
- ✅ Tested New Architecture vs Old Architecture — no difference
- ✅ Tested RN 0.83.2 and 0.84.1 — both affected
- ✅ Attempted
RCTSetDefaultFontHandler with AppleColorEmoji in cascade list — no effect
- ❌ Unable to test on iOS 18 simulator (Xcode 26 only ships iOS 26 runtime)
Notes
- This may be an iOS 26 simulator-specific issue (real devices may be unaffected)
- The root cause appears to be in how React Native's native text rendering (via CoreText/TextKit) resolves the emoji font cascade on iOS 26
- No older iOS simulator runtimes are available through Xcode 26 to compare
Description
Emoji characters render as
[?]placeholder boxes in React Native<Text>components on the iOS 26 simulator (Xcode 26.3, build 17C529). This affects all emoji — inline, standalone, flag sequences, and Unicode escape sequences.Safari running in the same simulator renders emoji correctly, confirming the font (
AppleColorEmoji) is present and registered. The issue is specific to React Native's CoreText text rendering path.Steps to reproduce
@react-native-community/cli)<Text>component:[?]boxesExpected behavior
Emoji should render using the AppleColorEmoji font, as they do in Safari and native UIKit apps on the same simulator.
Actual behavior
All emoji render as
[?]replacement characters/boxes.Environment
Investigation done
AppleColorEmoji-160px.ttcexists in the simulator runtime atCoreAddition/AppleColorEmoji-160px.ttcCTFontManagerRegisterFontsForURLreturns "already exists")RCTSetDefaultFontHandlerwith AppleColorEmoji in cascade list — no effectNotes